Mybatis——返回值(resultType&resultMap)详解

之前的文章里面有对resultType和resultMap的简单介绍这一期出点详细的

resultType:

1,返回值为简单类型。

直接使用resultType="类型",如string,Integer等。

java 复制代码
 String getEmpNameById(Integer id);
java 复制代码
<!-- 
        指定 resultType 返回值类型时 String 类型的,
        string 在这里是一个别名,代表的是 java.lang.String 

        对于引用数据类型,都是将大写字母转小写,比如 HashMap 对应的别名是 'hashmap'
        基本数据类型考虑到重复的问题,会在其前面加上 '_',比如 byte 对应的别名是 '_byte'
    -->
    <select id="getEmpNameById" resultType="string">
        select username from t_employee where id = #{id}
    </select>

2.返回值为List类型。

使用resultType="list元素的类型",一般是实体类如User,也可以是Map,对应返回值类型是List<User> , List<Map<String,Object>>,不管是哪种,最终结果会根据接口返回值类型自动将多个 resultType指定的类型的元素(User或以一条记录为一个Map)组装成List。

java 复制代码
 List<User> getUser(String age);
java 复制代码
<select id="getUser" resultType="User">
        select * from user
        where
        age = #{age}
    </select>
java 复制代码
 List<Map<String,Object>> findUserList();
java 复制代码
 <select id="findUserList"  parameterType="int" resultType="java.util.Map">
        SELECT * FROM user
    </select>

用java.util.List也是可以的,java.util.Map也是可以的至于为什么我没有没有研究过

3.返回值为Map类型。(使用map要注意查询结果的条数,多条会报错)

  1. 如果查询的结果是一条,我们可以把查询的数据以{表字段名, 对应的值}方式存入到Map中。
java 复制代码
   Map<String, Object> getEmpAsMapById(Integer id);
java 复制代码
  <!-- 
        注意这里的 resultType 返回值类型是 'map'
     -->
    <select id="getEmpAsMapById" resultType="map">
        select * from t_employee where id = #{id}
    </select>
  1. 如果查询的结果是多条数据,我们也可以把查询的数据以{表中某一字段名, JavaBean}方式来封装成Map
java 复制代码
// 查询所有员工的信息,把数据库中的 'id' 字段作为 key,对应的 value 封装成 Employee 对象
    // @MapKey 中的值表示用数据库中的哪个字段名作 key
    @MapKey("id")
    Map<Integer, Employee> getAllEmpsAsMap();
java 复制代码
 <!--
        注意 resultType 返回值类型,不再是 'map',而是 Map 的 value 对应的 JavaBean 类型
    -->
    <select id="getAllEmpsAsMap" resultType="employee">
        select * from t_employee
    </select>

扩展. 上面返回结果的形式都是基于查询 (select) 的,其实对于增删改的操作也可以返回一定类型的数据,比如BooleanInteger等。

resultMap:

属于自定义的映射,用于由于各种原因数据库的字段名跟实体类的字段名不一致

1.Emp实体类的属性:

java 复制代码
    private Integer empId;
    private String empName;
    private Integer age;
    private String gender;

2.表字段名:

|--------|----------|-----|--------|---------|
| emp_id | emp_name | age | gender | dept_id |

3.映射文件配置:

java 复制代码
<!--  Emp getEmpById(@Param("emp_id") Integer emp_id);-->
    <select id="getEmpById" resultType="Emp">
        select * from t_emp where emp_id = #{emp_id}
    </select>

4.执行结果发现empId=null,empName=null

原因:数据库表字段名中的emp_id,emp_name与实体类的属性名empId,empName不一致,由数据库不能映射到实体类属性对应的属性名

1. 方式一 字段名设置别名

java 复制代码
select emp_id empid from emp where emp_id  =  #{emp_id}

2. 方式二 下划线映射为驼峰(在配置文件中配置)

java 复制代码
<!--引入properties文件,此时就可以${属性名}的方式访问属性值-->
    <properties resource="jdbc.properties"/>
 
<!--配置mybatis自动转换为驼峰式命名-->
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
        <!--开启延迟加载-->
        <setting name="lazyLoadingEnabled" value="true" />
    </settings>

3. 方式三 自定义映射resultMap

resultMap: 设置自定义的映射关系
id: 唯一标识-->resultMap=" "
type: 处理映射关系的实体类的类型
标签:
id: 处理主键和实体类中属性的映射关系
result: 处理普通字段和实体类中属性的映射关系
column: 设置映射关系中的字段名,必须是sql中的某字段
property: 设置映射关系中的属性的属性名,必须为实体类中的属性名

java 复制代码
 <resultMap id="empDeptMapResultMapOne" type="Emp">
        <id property="eid" column="eid"></id>
        <result property="empName" column="emp_name"></result>
        <result property="age" column="age"></result>
        <result property="sex" column="sex"></result>
        <result property="email" column="email"></result>
        <result column="did" property="dept.did"></result>
        <result column="dname" property="dept.dname"></result>
 
  </resultMap>
 
<select id="getEmpAndDept" resultMap="empDeptMapResultMapTwo">
        select emp.*,dept.* from emp left join dept on emp.did = dept.did where emp.eid = #{eid}
 </select>
相关推荐
暴躁小师兄数据学院15 分钟前
【AI大数据工程师特训笔记】第04讲:PostgreSQL 数据库内置函数详解
大数据·数据库·笔记·ai·语言模型
JAVA面经实录91728 分钟前
MyBatis学习体系
java·mybatis
苏渡苇1 小时前
Spring Cloud Alibaba:将 Sentinel 熔断限流规则持久化到 Nacos 配置中心
数据库·spring boot·mysql·spring cloud·nacos·sentinel·持久化
杨云龙UP1 小时前
Oracle Recycle Bin 回收站详解:DROP TABLE 后还能找回吗?
linux·运维·数据库·sql·mysql·oracle
未来之窗软件服务1 小时前
酒店门锁V10SDK接口VB-幽冥大陆(一百26)—东方仙盟
数据库·酒店门锁·仙盟创梦ide·东方仙盟·东方仙盟sdk·东方仙盟幽冥大陆
墨_风2 小时前
MyBatis时间区间查询异常排查(达梦数据库)
数据库·mybatis·达梦
njsgcs2 小时前
用clip把设计经验变成向量数据库,然后每秒检索可以检查3维模型设计的错误吗
数据库
WiChP3 小时前
【V0.1B10】从零开始的2D游戏引擎开发之路
java·数据库·游戏引擎
小当家.1053 小时前
PostgreSQL 做向量数据库:pgvector 在 RAG 中的实战与多场景适配
数据库·人工智能·postgresql·rag
Access开发易登软件3 小时前
Access 和 SQLite,根本不在一个赛道上
java·jvm·数据库·sqlite·excel·vba·access开发