iteye_20392 2011-03-05 10:43
浏览 933
已采纳

mybatis resultMap 递归 Tree 的写法

 

/** 系统菜单 */
public class SysMenu {

    private int menuid; // 菜单编号
    private String menuname; // 菜单名
    private SysMenu parent; // 父菜单编号
    private List<SysMenu> children; //子菜单
    private int isleaf; // 是否是叶子节点
    private String action; // 响应类在缓存中的key
    private int sort; // 序号
    private int activity; // 是否可用
    private String describe; // 描述
   <resultMap type="sysMenu" id="sysMenuResult">
        <id property="menuid" column="menuid"/>
        <result property="menuname" column="menuname"/>
        <result property="isleaf" column="isleaf"/>
        <result property="action" column="action"/>
        <result property="sort" column="sort"/>
        <result property="activity" column="activity"/>
        <result property="describe" column="describe"/>
    </resultMap>
    
    <select id="searchMenusByParentId" parameterType="int" resultMap="sysMenuResult">
        select 
          `menuid` , `menuname` , `parentid` , `isleaf` , `action` , `sort` , `activity` , `describe` 
        from `sys_menu` 
        where `activity` = 1 and `parentid` = #{menuid}
    </select>

关于属性 : private SysMenu parent; // 父菜单编号

             private List<SysMenu> children; //子菜单

  resultMap 中的写法?

  • 写回答

2条回答 默认 最新

  • linvar 2011-03-05 22:46
    关注

    可以使用外连接, 你那种方式会导致N+1连接问题...
    就是本来一次就可以得到的数据,你分了N次请求,

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 关于#linux#的问题:子进程1等待子进程A、B退出后退出(语言-c语言)
  • ¥15 io.jsonwebtoken.security.Keys
  • ¥15 急,ubuntu安装后no caching mode page found等
  • ¥15 联想交换机NE2580O/NE1064TO安装SONIC
  • ¥15 防火墙的混合模式配置
  • ¥15 Ubuntu不小心注销了要怎么恢复啊
  • ¥15 win10电脑安装完plcsim advanced4.0运行时为什么会提示找不到虚拟网卡
  • ¥15 安装powerbuilder10卡在安装程序正在运行这个页面 没有下一步任何指令
  • ¥15 关于mpi的问题:请问遇到这种情况需要怎么解决,出现这个问题后电脑不能进行mpi多核运行只能进行单核运行
  • ¥50 微信聊天记录备份到电脑提示成功了,但还是没同步到电脑微信