今天看啥  ›  专栏  ›  牛哄哄的柯南

Mybatis的返回值深入

牛哄哄的柯南  · CSDN  ·  · 2021-02-08 23:16

resultType 配置结果类型

(1)resultType 属性可以指定结果集的类型,它支持基本类型和实体类类型。我们在前面的 CRUD 案例中已经对此属性进行过应用了。
(2)需要注意的是,它和 parameterType 一样,如果注册过类型别名的,可以直接使用别名。没有注册过的必须使用全限定类名。例如:我们的实体类此时必须是全限定类名(今天最后一个章节会讲解如何配置实体类的别名)
(3)同时,当是实体类名称是,还有一个要求,实体类中的属性名称必须和查询语句中的列名保持一致,否则无法实现封装。

基本类型示例

Dao 接口

/**
* 查询总记录条数
* @return
*/
int findTotal();
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

映射配置

<!-- 查询总记录条数 --> 
<select id="findTotal" resultType="int">
select count(*) from user;
</select>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

实体类类型示例

Dao 接口

/**
* 查询所有用户
* @return
*/
List<User> findAll();
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

映射配置

<!-- 配置查询所有操作 --> 
<select id="findAll" resultType="com.keafmd.domain.User">
select * from user
</select>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

特殊情况示例

修改实体类

实体类代码如下:(此时的实体类属性和数据库表的列名已经不一致了)

public class User implements Serializable {
    private Integer userId;
    private String userName;
    private Date userBirthday;
    private String userSex;
    private String userAddress;

    public Integer getUserId() {
        return userId;
    }

    public void setUserId(Integer userId) {
        this.userId = userId;
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public Date getUserBirthday() {
        return userBirthday;
    }

    public void setUserBirthday(Date userBirthday) {
        this.userBirthday = userBirthday;
    }

    public String getUserSex() {
        return userSex;
    }

    public void setUserSex(String userSex) {
        this.userSex = userSex;
    }

    public String getUserAddress() {
        return userAddress;
    }

    public void setUserAddress(String userAddress) {
        this.userAddress = userAddress;
    }

    @Override
    public String toString() {
        return "User [userId=" + userId + ", userName=" + userName + ", userBirthday="
                + userBirthday + ", userSex="
                + userSex + ", userAddress=" + userAddress + "]";
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54

Dao 接口

/**
* 查询所有用户
* @return
*/
List<User> findAll();
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

映射配置

<!-- 配置查询所有操作 --> 
<select id="findAll" resultType="com.keafmd.domain.User">
select * from user
</select>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

测试查询结果

@Test
public void testFindAll() {
   List<User> users = userDao.findAll();
   for(User user : users) {
       System.out.println(user);
   } 
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

输出结果:
在这里插入图片描述
名称会有值,是因为:mysql 在 windows 系统中不区分大小写!

修改映射配置

使用别名查询

<!-- 配置查询所有操作 --> 
<select id="findAll" resultType="com.keafmd.domain.User">
select id as userId,username as userName,birthday as userBirthday,sex as userSex,address as userAddress from user
</select>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

输出结果:
在这里插入图片描述

如果我们的查询很多,都使用别名的话写起来会很麻烦,有别的解决办法,继续往下面看。

resultMap 结果类型

(1)resultMap 标签可以建立查询的列名和实体类的属性名称不一致时建立对应关系。从而实现封装。
(2)在 select 标签中使用 resultMap 属性指定引用即可。同时 resultMap 可以实现将查询结果映射为复杂类型的 pojo,比如在查询结果映射对象中包括 pojo 和 list 实现一对一查询和一对多查询。

定义 resultMap

<!-- 建立 User 实体和数据库表的对应关系
type 属性:指定实体类的全限定类名
id 属性:给定一个唯一标识,是给查询 select 标签引用用的。--> 
<resultMap type="com.itheima.keafmd.User" id="userMap"> <id column="id" property="userId"/>
<result column="username" property="userName"/>
<result column="sex" property="userSex"/>
<result column="address" property="userAddress"/>
<result column="birthday" property="userBirthday"/>
</resultMap>
<!-- id 标签:用于指定主键字段
result 标签:用于指定非主键字段
column 属性:用于指定数据库列名
property 属性:用于指定实体类属性名称--> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

映射配置

<!-- 配置查询所有操作 --> 
<select id="findAll" resultMap="userMap">
     select * from user
</select>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

测试结果

@Test
public void testFindAll() {
   List<User> users = userDao.findAll();
   for(User user : users) {
      System.out.println(user);
   } 
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

输出结果:
在这里插入图片描述

这样即使是别名,也都可以查询到,同时相比于上面的在sql语句中进行别名操作对于开发更加方便,但是上面的方法更高效。

以上就是Mybatis的返回值深入的全部内容。

看完如果对你有帮助,感谢点赞支持!
如果你是电脑端的话,看到右下角的 “ 一键三连 ” 了吗,没错点它[哈哈]

在这里插入图片描述

加油!

共同努力!

Keafmd




原文地址:访问原文地址
快照地址: 访问文章快照