6. Mybatis resultMap

本文深入探讨了MyBatis框架中的resultMap元素,它是MyBatis最强大且关键的组成部分,能够极大简化从数据库结果集中抽取数据的过程,甚至实现一些JDBC无法做到的功能。通过示例展示了如何使用resultMap来解决列名与JavaBean属性不匹配的问题。
resultMap 元素是MyBatis中最重要最强大的元素。它就是让你远离90%的需要从结果集中取出数据的JDBC代码的那东西,而且在一些情形下允许你做一些JDBC不支持的事情。事实上,编写相似于对复杂语句联合映射这些等同的代码,也许可以跨过上千行的代码。ResultMap的设计就是简单语句不需要明确的结果映射,而很多复杂语句确实需要描述它们的关系。
 
package com.accp.mybatis.model;  
  
public class Blog {  
    private Integer id;  
    private String title;  
    private Integer authorId;  
  
//省略get和set方法  
}  

基于JavaBean的规范,上面这个类有3个属性:id,title和authorId。这些在select语句中会精确匹配到列名。
这样的一个JavaBean可以被映射到结果集,就像映射到HashMap一样简单。

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper  
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
<mapper namespace="com.accp.mybatis.model.Blog">    
      
    <select id="selectBlog_by_id" parameterType="int" resultType="Blog">  
        select * from Blog where id = #{id}  
    </select>  
  
</mapper>  

这些情况下,MyBatis会在幕后自动创建一个ResultMap,基于属性名来映射列到JavaBean的属性上。如果列名没有精确匹配,你可以在列名上使用select字句的别名(一个标准的SQL特性)来匹配标签。
ResultMap最优秀的地方你已经了解了很多了,但是你还没有真正的看到一个。只是出于示例的原因,让我们来看看最后一个示例中外部的resultMap是什么样子的,这也是解决列名不匹配的另外一种方式。

<resultMap id="Blog_result" type="Blog" >  
    <id column="id" property="id" />  
    <result column="title" property="title"/>  
    <result column="author_id" property="authorId"/>  
</resultMap>  

引用它的语句使用resultMap属性就行了(注意我们去掉了resultType属性)。比如:

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper  
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
<mapper namespace="com.accp.mybatis.model.Blog">  
  
  
    <resultMap id="Blog_result" type="Blog" >  
        <id column="id" property="id" />  
        <result column="title" property="title"/>  
        <result column="author_id" property="authorId"/>  
    </resultMap>    
  
    <!-- resultType与resultMap不能同时使用 -->     
    <select id="selectBlog_by_id" parameterType="int" resultMap="Blog_result">  
        select * from Blog where id = #{id}  
    </select>  
  
</mapper>  

 

转载于:https://www.cnblogs.com/shix0909/p/11149224.html

### MyBatis 查询返回 `com.example.mybatis.UserInfo` 对象数组的实现方法 在 MyBatis 中,查询结果可以通过 `resultType` 或 `resultMap` 映射到指定的对象类型。如果需要返回一个对象数组(如 `List<UserInfo>`),可以通过以下方式实现: #### 1. 使用 `resultType` 返回对象数组 如果查询结果的字段名与 `UserInfo` 类的属性名一致,则可以直接使用 `resultType` 指定返回类型为 `com.example.mybatis.UserInfo`。MyBatis 会自动将查询结果映射到 `UserInfo` 对象,并以列表形式返回。 ```xml <select id="selectUserInfos" resultType="com.example.mybatis.UserInfo"> SELECT id, username, email, phone FROM user_info </select> ``` 上述代码中,`resultType="com.example.mybatis.UserInfo"` 表示将查询结果映射为 `UserInfo` 对象[^3]。如果数据库表中的字段名与 `UserInfo` 的属性名不一致,可以使用 SQL 别名进行映射[^4]。 #### 2. 使用 `resultMap` 处理复杂映射 当字段名和属性名不一致或存在复杂映射时,可以定义 `resultMap` 来手动指定映射规则。 ```xml <resultMap id="userInfoResultMap" type="com.example.mybatis.UserInfo"> <id property="id" column="user_id"/> <result property="username" column="user_name"/> <result property="email" column="user_email"/> <result property="phone" column="user_phone"/> </resultMap> <select id="selectUserInfos" resultMap="userInfoResultMap"> SELECT user_id, user_name, user_email, user_phone FROM user_info </select> ``` 在此示例中,`resultMap` 定义了如何将数据库字段映射到 `UserInfo` 对象的属性[^4]。通过这种方式,即使字段名与属性名不同,也可以正确映射。 #### 3. Java 接口定义 在 MyBatis 的 Mapper 接口中,定义一个方法来调用上述 SQL 查询。 ```java public interface UserInfoMapper { List<UserInfo> selectUserInfos(); } ``` 调用该方法时,MyBatis 会根据配置返回一个包含多个 `UserInfo` 对象的列表。 #### 4. 示例代码:查询并返回对象数组 以下是一个完整的示例,展示如何通过 MyBatis 查询并返回 `UserInfo` 对象数组。 ```java // UserInfo.java public class UserInfo { private Integer id; private String username; private String email; private String phone; // Getters and Setters } // UserInfoMapper.xml <select id="selectUserInfos" resultType="com.example.mybatis.UserInfo"> SELECT id, username, email, phone FROM user_info </select> // UserInfoMapper.java public interface UserInfoMapper { List<UserInfo> selectUserInfos(); } // 调用示例 List<UserInfo> userInfos = userInfoMapper.selectUserInfos(); for (UserInfo userInfo : userInfos) { System.out.println(userInfo.getUsername()); } ``` #### 注意事项 - 如果查询结果为空,MyBatis 将返回一个空列表而不是 `null`。 - 确保 `UserInfo` 类的属性名与数据库字段名匹配,或者通过 `resultMap` 进行手动映射[^3]。 - 如果需要处理一对多或多对多关系,可以使用嵌套结果映射[^1]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值