本文共 2721 字,大约阅读时间需要 9 分钟。
接口中添加方法:
配置文件中添加配置: 在单元测试中添加测试方法,运行成功
(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);
配置文件中添加配置:
在单元测试中添加测试方法,运行成功:
/*Mapmap = mapper.getEmpByIdReturnMap(1); System.out.println(map);*/ /*Map map = mapper.getEmpByLastNameLikeReturnMap("%r%"); System.out.println(map);*/
(1)基本用法
(2)关联查询(多表查询)
1)外键约束
2)接口中添加方法
3)映射配置文件中添加配置(一):联合查询:级联属性封装结果集 3)映射配置文件中添加配置(二):使用association定义关联对象封装规则
3)映射配置文件中添加配置(三):使用association进行分步查询
在步骤2)中添加方法
在EmployeeMapperPlus.xml添加配置:
public Employee getEmpByIdStep(Integer id);
在DepartmentMapper.xml中创建getDeptById关联EmployeeMapperPlus.xml中select
4)编写测试方法,运行成功 
可以使用延迟加载(也叫懒加载或按需加载)
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/