mybatis-5-关联查询
外键查询
1、回忆外键约束
注意要在tbl_dept中添加外键
#添加外键约束
# 此处Employee为外键表,dept为主键表
# 删除Employee的数据不会影响dapt,而删除dept一定会影响employee,这是为了保证数据的一致性
alter table tbl_employee add constraint fk_emp_dept
foreign key (d_id) references tbl_dept(id);
2、sql的关联查询
SELECT e.`id` id,e.gender gender,e.`last_name` last_name,e.`email` email, e.`d_id` d_id ,d.`dept_name`
FROM tbl_employee e,tbl_dept d
WHERE e.d_id = d.id
AND e.id = 4;
3、resultMap关联查询
== 一定要注意的是:association使用的是javaType,collection使用的是ofType,如果他们使用的是分步查询,那么这两个属性都不需要写 ==
使用assocition映射封装(多对一)javaType
(不使用外键情况下)
<resultMap id="EmployeeMap" type="Employee">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="gender" property="gender"/>
<result column="email" property="email"/>
<!--property为联级类的名字,javaType为联级类的类别-->
<association property="department" javaType="Department">
<id column="did" property="id"/>
<result column="dept_name" property="departmentName"/>
</association>
</resultMap>
<select id="getEmployeeList" resultMap="EmployeeMap">
select e.id,e.last_name,e.gender,e.email,d.id did,d.dept_name
from tbl_employee e,tbl_dept d
where e.d_id = d.id;
</select>
使用assocition分步查询(多对一)
查询员工时把员工的部门也查询出来
主要使用在数据查询很大的时候:
- 分布查询可以做到使用现有接口方法来达到实现封装的目的
- 分布查询可以实现延时加载,节省资源
<!--使用resultMap分步查询-->
<!--1、先按照员工id查询员工信息
2、根据员工信息中的d_id值去查出部门信息
3、部门设置到员工中
-->
<resultMap id="EmployeeMapStep" type="Employee">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="gender" property="gender"/>
<result column="email" property="email"/>
<!--association定义关联对象的封装规则、
select:指明当前属性是调用哪个方法查出的结果
column:指定将哪一列的值传给方法
流程:使用select指定的方法(传入column指定的值)查除对象,把地址赋值给原来封装对象的相关属性
-->
<association property="department"
select="com.wang.Dao.DepartmentMapper.getDepartmentById"
column="d_id"/>
</resultMap>
<!-- Employee getEmployeeById(Integer id);-->
<select id="getEmployeeById" resultMap="EmployeeMapStep">
select * from tbl_employee where id =#{id};
</select>
使用collection实现映射封装(一对多)ofType
查询部门的时候把部门内包含的员工也查询出来
接口:
public interface DepartmentMapper {
Department getDepartmentById(Integer id);
}
bean类
private int id;
private String departmentName;
private List<Employee> employeeList;
Mapper配置文件中
<resultMap id="DepartmentMap" type="Department">
<id column="did" property="id"/>
<result column="dept_name" property="departmentName"/>
<!--collection定义关联集合类型的封装规则-->
<!--我们需要把用did查询到的数据封装成Lst对像-->
<!--
property:属性名称
ofType:指定集合里面的元素
-->
<collection property="employeeList" ofType="Employee">
<!--定义这个集合元素中的封装规则-->
<id column="eid" property="id"/>
<result column="gender" property="gender"/>
<result column="last_name" property="lastName"/>
<result column="email" property="email"/>
</collection>
</resultMap>
<select id="getDepartmentById" resultMap="DepartmentMap">
select d.id did,d.dept_name,e.id eid,e.last_name,e.gender,e.email
from tbl_dept d
left join tbl_employee e
on d.id = e.d_id
where d.id = #{id};
</select>
在分布查询基础上实现延时加载
之前我们在查询Employee对象时,内部的属性都将被查询出来
单这样将占用大量内存
我们需要做到:部门信息在我们需要的时候再起查询
这个时候我们只需要在分步查询的基础在全局配置上加上两个配置
<!--开启懒加载,在需要的时候才会读取数据 -->
<setting name="lazyLoadingEncoding" value="true"/>
<!--关闭强制加载,即关闭在加载实例的时候就读取全部数据-->
<setting name="aggressiveLazyLoading" value="false"/>
或者:在collection和association标签上加上fetch属性即可
<association property="department" //不需要oftype属性
select="com.wang.Dao.DepartmentMapper.getDepartmentById"
column="{id = d_id}"
fetchType="lazy"/>
<!--fetchType表示获取数据的方式
lazy:懒加载
eager:立即加载
-->
分步查询拓展-传入多个参数
有时候需要把多个字段值传入调用的方法
做法:将多个字段的值封装成Map传递
注意点:键一定要是传入方法的参数名
column="{id = d_id,name = dept_name}"
4、discriminator鉴别器使用(进行简单的判断操作)
鉴别器:mybatis可以使用discriminator判断某列的值,然后根据某列的值改变封装的行为
现在有这样的需求:
如果查出来是女生,就把部门信息查询出来,否则不查询
如果查出来是男生,就把last_name这一字段的值赋值给email
注意点:case里的javatype或者说javaMap不可或缺,如果加入javaMap则表示在这个case情况下我们调用另外一种sql映射规则
<mapper namespace="com.wang.Dao.EmployeeMapper">
<!-- //获取全部员工的信息-->
<!-- Employee getEmployeeById(int id);-->
<resultMap id="EmployeeMap" type="Employee">
<!--column:指定判定的列名
javaType:列名对应的java类型,注意开头因为经过转换所以为小写-->
<discriminator javaType="string" column="gender">
<!--1是男生-->
<case value="男" resultType="com.wang.Pojo.Employee">
<id column="id" property="id"/>
<result column="email" property="lastName"/>
<result column="gender" property="gender"/>
<result column="last_name" property="email"/>
<!-- <association property="department"
select="com.wang.Dao.DepartmentMapper.getDepartmentByDid"
column="d_id"/>-->
</case>
<!--0是女生-->
<case value="女" resultType="com.wang.Pojo.Employee">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="gender" property="gender"/>
<result column="email" property="email"/>
<association property="department"
select="com.wang.Dao.DepartmentMapper.getDepartmentByDid"
column="d_id"/>
</case>
</discriminator>
</resultMap>
mybatis-5-关联查询的更多相关文章
- Mybatis之关联查询
一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关 ...
- SpringBoot+Mybatis实现关联查询
SpringBoot+Mybatis实现关联查询 今天学习了下Mybatis的动态查询,然后接着上次的Demo改造了下实现表的关联查询. 话不多说,开始今天的小Demo 首先接着上次的项目 https ...
- Mybatis之关联查询及动态SQL
前言 实际开发项目中,很少是针对单表操作,基本都会联查多表进行操作,尤其是出一些报表的内容.此时,就可以使用Mybatis的关联查询还有动态SQL.前几篇文章已经介绍过了怎么调用及相关内容,因此这里只 ...
- JavaWeb_(Mybatis框架)关联查询_六
系列博文: JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一 传送门 JavaWeb_(Mybatis框架)使用Mybatis对表进行增.删.改.查操作_ ...
- mybatis一对一关联查询——(八)
1.需求 查询所有订单信息,关联查询下单用户信息. 注意: 因为一个订单信息只会是一个人下的订单,所以从查询订单信息出发关联查询用户信息为一对一查询.如果从用户信息出发查询用户下的订单信息则为一对多查 ...
- Mybatis一对一关联查询
有两张表,老师表teacher和班级表class,一个class班级对应一个teacher,一个teacher对应一个class 需求是根据班级id查询班级信息(带老师的信息) 创建teacher和c ...
- MyBatis学习(四)MyBatis一对一关联查询
一对一关联查询即.两张表通过外键进行关联.从而达到查询外键直接获得两张表的信息.本文基于业务拓展类的方式实现. 项目骨架 配置文件conf.xml和db.properties前几节讲过.这里就不细说了 ...
- SSM-MyBatis-15:Mybatis中关联查询(多表操作)
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 先简单提及一下关联查询的分类 1.一对多 1.1单条SQL操作的 1.2多条SQL操作的 2.多对一 2.1单 ...
- Mybatis的关联查询(一)
一对一的关联查询 一.使用resultType进行输出映射 1. 创建一个新的PO类,由于要将查询出来的属性映射到新的PO类.所有该PO类中应该有查询出来的所有列对应的属性. //定义新的PO类, ...
- MyBatis的关联查询
关联映射的一对多 //查询经理角色 以及 该角色下对应的员工集合 public SmbmsRole getRoleAndUser(Integer id); <resultMap id=" ...
随机推荐
- 如何在TVM上集成Codegen(下)
如何在TVM上集成Codegen(下) Bring DNNL to TVM: JSON Codegen/Runtime 现在实现将中继图序列化为JSON表示的DNNL codegen,然后实现DNNL ...
- Samsung WLAN AP RCE漏洞及利用工具
1.漏洞详情: 三星 WLAN AP WEA453e 路由器 远程命令执行 2.fofa语句 title=="Samsung WLAN AP" 3.复现 payload: POST ...
- Mybatis映射文件中的参数传递
一.接口中只有一个参数 1.参数是基本类型or基本类型的包装类or字符串类型 这种情况下映射文件中#{}里的内容可以是任意的,你可以使用#{xxx} 或 #{abc} .....因为此时#{}相当于一 ...
- 简单理解数据库连接池(JDBC)
为什么要使用连接池? 在我们写代码的时候,写了很多类,假如这些类都和数据库打交道.这样的话每个类都要去获取数据库连接,操作完了之后就把连接释放了. 要知道,获取数据库连接的操作其实是向操作系统底层去获 ...
- python做。大神空闲时间能帮忙弄一串代码嘛?猜拳游戏,分很多种手的背面和正面,最后剩下的再石头剪刀布
.每天课程结束后,老师会选择一列的同学清扫教室,人数不定(建议根据当时情况输入),在收拾完教室后,最后一步是需要从这一列的同学中选择1-2人去倒垃圾桶,垃圾桶数量根据当时情况决定,目前采取的方式是, ...
- 【NX二次开发】Block UI 操作按钮
属性说明 常规 类型 描述 BlockID String 控件ID Enable Logical 是否可操作 Group Logical ...
- 【ElasticSearch】给ElasticSearch数据库配置慢查询日志
给ElasticSearch引擎配置慢查询日志,可以实时监控搜索过慢的日志.虽然ElasticSearch以快速搜索而出名,但随着数据量的进一步增大或是服务器的一些性能问题,会有可能出现慢查询的情况. ...
- Shiro-JWT SpringBoot前后端分离权限认证的一种思路
JWT-Shiro 整合 JWT-与Shiro整合进行授权认证的大致思路 图示 大致思路 将登录验证从shiro中分离,自己结合JWT实现 用户登陆后请求认证服务器进行密码等身份信息确认,确认成功后 ...
- 禁止特定IP访问Oracle数据库
通过使用数据库服务器端的sqlnet.ora文件可以实现禁止指定IP主机访问数据库的功能,这对于提升数据库的安全性有很大的帮助,与此同时,这个技术为我们管理和约束数据库访问控制提供了有效的手段 在sq ...
- mybatis-generator的使用心得
之前开发了一个亚健康测评系统,使用的是SSM框架,里面第一次使用到了mybatis-generator逆向代码生成工具,很方便,省去了基本的增删改查的mapper文件及sql的编写,还能避免错误,这里 ...