博客
关于我
学习在IDEA中使用Mybatis(四)select对应参数
阅读量:392 次
发布时间:2019-03-05

本文共 2721 字,大约阅读时间需要 9 分钟。

1. select—resultType(返回值类型)

1).返回list

接口中添加方法:

在这里插入图片描述
配置文件中添加配置:

在单元测试中添加测试方法,运行成功

在这里插入图片描述

2).返回Map

(1)单条记录的封装:key就是列名,值就是对应的值

接口中添加方法:
在这里插入图片描述
配置文件中添加配置:

在单元测试中添加测试方法,运行成功

在这里插入图片描述
(2)多条记录的封装: Map<Integer,Employee> —键是这条记录的主键,值是记录封装后的JavaBean**
接口中添加方法:

//多条记录封装一个map:Map
:键是这条记录的主键,值是记录封装后的javaBean //@MapKey:告诉mybatis封装这个map的时候使用哪个属性作为map的key @MapKey("lastName") // 也可换"id",对应Map中改成Integer即可取出主键值 public Map
getEmpByLastNameLikeReturnMap(String lastName);

配置文件中添加配置:

在单元测试中添加测试方法,运行成功:

/*Map
map = mapper.getEmpByIdReturnMap(1); System.out.println(map);*/ /*Map
map = mapper.getEmpByLastNameLikeReturnMap("%r%"); System.out.println(map);*/

2. select—resultMap

(1)基本用法

(2)关联查询(多表查询)

1)外键约束
在这里插入图片描述
2)接口中添加方法
在这里插入图片描述
3)映射配置文件中添加配置(一):联合查询:级联属性封装结果集

3)映射配置文件中添加配置(二):使用association定义关联对象封装规则

3)映射配置文件中添加配置(三):使用association进行分步查询

在步骤2)中添加方法
在这里插入图片描述

在EmployeeMapperPlus.xml添加配置:

public Employee getEmpByIdStep(Integer id);

在DepartmentMapper.xml中创建getDeptById关联EmployeeMapperPlus.xml中select

在这里插入图片描述

4)编写测试方法,运行成功 在这里插入图片描述

(3)分步查询—延迟加载

可以使用延迟加载(也叫懒加载或按需加载)

Employee==>Dept:我们每次查询Employee对象的时候,都将一起查询出来。而部门信息可以在我们使用的时候再去查询,即分段查询的基础之上在全局配置文件中加上如下两个配置:

在全局配置文件中加上如下配置

在这里插入图片描述
(4)resultMap — collection定义关联集合封装规则
1)实例:查询部门的时候将部门对应的所有员工信息也查询出来。
解析:需要用collcetion将部门对应所有员工信息封装到一个LIst中
1.在部门实体类中添加private List<Employee> emps以及相应的set和get方法。
2.在departmentMapper配置文件中添加配置
在这里插入图片描述
3.测试方法中实现
在这里插入图片描述
2)实现collection分步查询
1.先查询Employee中的Id
在这里插入图片描述
2.再根据Id从department进行查询
在这里插入图片描述
3)扩展:多列的值传递过去:
将多列的值封装map传递;
column="{key1=column1,key2=column2}"
fetchType=“lazy”:表示使用延迟加载;
- lazy:延迟
- eager:立即
在这里插入图片描述
(4)鉴别器 — discriminator
mybatis可以使用discriminator判断某列的值,然后根据某列的值改变封装行为
封装Employee:
如果查出的是女生:就把部门信息查询出来,否则不查询;
如果是男生,把last_name这一列的值赋值给email;

转载地址:http://pvewz.baihongyu.com/

你可能感兴趣的文章
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>