MyBatis从入门到精通:select较深层次的用法
一,简单的情形
需求:
根据用户id获取用户拥有的所有角色,返回的结果为角色集合。
1.接口中增加的方法:
List<SysRole> selectRolesByUserId(Long userId);
2.映射文件做出的修改:
    <select id="selectRolesByUserId" resultType="tk.mybatis.simple.model.SysRole">
        SELECT
          r.id,
          r.role_name roleName,
          r.enabled,
          r.create_by createBy,
          r.create_time createTime,
        FROM sys_user u
        INNER JOIN sys_user_role ur on u.id = ur.user_id
        INNER JOIN sys_role r on ur.role_id = r.id
        WHERE u.id = #{userId}
    </select>
二,复杂的情形
需求:
以第一中情形为基础,假设查询的结果不仅要版哈sys_role中的信息,还要包括当前用户的部分信息
方案一:
在SysRole类中直接添加useName属性,或者继承SysRole,在继承类中添加userName属性
方案二:
在SysRole类中添加SysUser类性的属性
1.接口中增加的方法:
List<SysRole> selectRolesByUserId(Long userId);
2.映射文件做出的修改:
    <select id="selectRolesByUserId" resultType="tk.mybatis.simple.model.SysRole">
        SELECT
          r.id,
          r.role_name roleName,
          r.enabled,
          r.create_by createBy,
          r.create_time createTime,
          u.user_name AS "user.userName",
          u.user_email AS "user.userEmail"
        FROM sys_user u
        INNER JOIN sys_user_role ur on u.id = ur.user_id
        INNER JOIN sys_role r on ur.role_id = r.id
        WHERE u.id = #{userId}
    </select>
MyBatis从入门到精通:select较深层次的用法的更多相关文章
- MyBatis从入门到精通(二):MyBatis XML方式的基本用法之Select
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 明确需求 书中提到的需求是一个基 ... 
- MyBatis从入门到精通(一):MyBatis入门
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. MyBatis简介  2001 ... 
- MyBatis从入门到精通(三):MyBatis XML方式的基本用法之多表查询
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 多表查询 上篇博客中,我们示例的 ... 
- MyBatis从入门到精通(四):MyBatis XML方式的基本用法之增删改
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. insert用法 1.1 简单的 ... 
- MyBatis从入门到精通(五):MyBatis 注解方式的基本用法
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. @Select 注解 1.1 使 ... 
- MyBatis从入门到精通(六):MyBatis动态Sql之if标签的用法
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用if标签生成动 ... 
- MyBatis从入门到精通(七):MyBatis动态Sql之choose,where,set标签的用法
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用choose, ... 
- MyBatis从入门到精通(八):MyBatis动态Sql之foreach标签的用法
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用foreach ... 
- MyBatis从入门到精通(九):MyBatis高级结果映射之一对一映射
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解MyBatis中实现查 ... 
- MyBatis从入门到精通(十):使用association标签实现嵌套查询
		最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解使用associati ... 
随机推荐
- PowerDesigner逆向工程导入MYSQL数据库总结(不容易,感谢前者们)
			原文:PowerDesigner逆向工程导入MYSQL数据库总结(不容易,感谢前者们) 参考来源: http://blog.csdn.net/chamtianjiao/article/details/ ... 
- storm(一)
			Storm 一个用来实时计算的流框架,具有高可用,低延迟,数据不丢失,分布式的特点 storm 处理数据的方式是基于消息的流水线处理,因此特别适合无状态的计算,也就是说计算单元依赖的数据全部在接受的消 ... 
- clipboard.js在剪切中的使用
			目前只是对文字的复制. 下面的代码解释: 1.html 需要添加data-clipboard="copy"和data-clipboard-target="对象选择器&qu ... 
- SimpleMembership,成员资格提供程序、 通用的提供者和新的 ASP.NET 4.5 Web 窗体和 ASP.NET MVC 4 模板
			ASP.NET MVC 4 互联网模板中添加一些新的. 非常有用的功能,构建 SimpleMembership.这些更改将添加一些很有特色,像很多更简单. 可扩展会员 API 和 OAuth 的支持. ... 
- AspNetCore 小记
			1. Microsoft.AspNetCore.Hosting.IHostingEnvironment 的接口获取的值: WebRootPath:D:\参考资料\C#\AspNetCore开源项目\n ... 
- 使用 acl 编写 UDP 网络程序(UDP 重传及可靠性机制)
			在当今网络世界,虽然大部分网络应用都是基于 TCP 的,但有时 UDP 的网络通信也有用武之处.acl 的网络库中不仅提供了基于 TCP 的网络套接字流,同时也提供了 UDP 的网络库(目前 acl ... 
- 使用VS2010再装VS2013不用再烦恼不兼容
			某些同事有时在开发过程中出现这么个问题,在使用js直接异步调用类库时,弹出错误类库不存在或者没有定义等,类似问题,这个时候可能你正在绞尽脑汁的去解决问题,明明问题不大,为什么安装VS2013后就不能打 ... 
- 深入理解计算机系统 BombLab 实验报告
			又快有一个月没写博客了,最近在看<深入理解计算机系统>这本书,目前看完了第三章,看完这章,对程序的机器级表示算是有了一个入门,也对 C 语言里函数栈帧有了一个初步的理解. 为了加深对书本内 ... 
- 文件识别浅谈(含office文件区分)
			前言 本文主要根据后台接口识别Office文件类型这一话题做一些分享,主要方向还是放在不能获取到文件名情况下的Office文件识别. 可获取到文件名 如果后端接口可以获取到完成的文件名称,则整个过程会 ... 
- 关于linux网卡消失的问题
			首先我也是一名学生,在学习的过程Linux的过程中,因为老师要求配置hadoop集群所以就匆匆忙忙的上手了,但是在配置网络的问题时遇到了网卡消失的问题 我在网上询问了许多的人,但是还是没有找到一个很好 ... 
