之前的文章里面有对resultType和resultMap的简单介绍这一期出点详细的
String getEmpNameById(Integer id);
使用resultType=“list元素的类型”,一般是实体类如User,也可以是Map,对应返回值类型是List
List getUser(String age);
List
用java.util.List也是可以的,java.util.Map也是可以的至于为什么我没有没有研究过
1. 如果查询的结果是一条,我们可以把查询的数据以{表字段名, 对应的值}
方式存入到Map
中。
Map getEmpAsMapById(Integer id);
2. 如果查询的结果是多条数据,我们也可以把查询的数据以{表中某一字段名, JavaBean}
方式来封装成Map
。
// 查询所有员工的信息,把数据库中的 'id' 字段作为 key,对应的 value 封装成 Employee 对象
// @MapKey 中的值表示用数据库中的哪个字段名作 key
@MapKey("id")
Map getAllEmpsAsMap();
扩展. 上面返回结果的形式都是基于查询 (select
) 的,其实对于增删改的操作也可以返回一定类型的数据,比如Boolean
,Integer
等。
属于自定义的映射,用于由于各种原因数据库的字段名跟实体类的字段名不一致
1.Emp实体类的属性:
private Integer empId;
private String empName;
private Integer age;
private String gender;
2.表字段名:
emp_id | emp_name | age | gender | dept_id |
3.映射文件配置:
4.执行结果发现empId=null,empName=null
原因:数据库表字段名中的emp_id,emp_name与实体类的属性名empId,empName不一致,由数据库不能映射到实体类属性对应的属性名
select emp_id empid from emp where emp_id = #{emp_id}