java
主页 > 软件编程 > java >

Mybatis结果集映射与生命周期介绍

2022-10-11 | 秩名 | 点击:

一、ResultMap结果集映射

1、设计思想

对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了

2、resultMap的应用场景

下面这个是我的数据库表

然后这是我们对应的Java实体类User2,除了有参构造外,它还定义了一个无参构造,而且用户id字段为userId,与数据库表中的id不一致

我们在执行查询方法后可以发现,实体类中的userId和数据库表中的id字段没有办法被自动关联,所以查出来的结果中,userId字段是空

所以,为了解决这种问题,我们就需要用到resultMap结果集映射(当然,使用as关键字给字段取一个别名也可以解决此问题)

select id as userId,name,sex,age from t_decade_user;

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<?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.decade.mapper.UserMapper">

    <resultMap id="userInfo" type="com.decade.entity.User2">

        <result property="userId" column="id" jdbcType="VARCHAR"/>

        <result property="name" column="name" jdbcType="VARCHAR"/>

        <result property="sex" column="sex" jdbcType="VARCHAR"/>

        <result property="age" column="age" jdbcType="INTEGER"/>

    </resultMap>

    <select id="getUserInfoById" resultMap="userInfo">

        select * from t_decade_user where id = #{userId} and name =  #{name};

    </select>

</mapper>

我们在接口类中添加一个注解@Param,这样就可以避免参数绑定报错的问题(只有一个入参时,不会出现这种错误)

1

2

3

4

5

6

7

package com.decade.mapper;

import com.decade.entity.User2;

import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface UserMapper {

    List<User2> getUserInfoById(@Param("userId") String userId, @Param("name") String name);

}

最后写一个测试方法

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

import com.decade.entity.User2;

import com.decade.mapper.UserMapper;

import com.decade.utils.MybatisUtils;

import org.apache.ibatis.session.SqlSession;

import org.junit.Test;

import java.util.List;

public class UserDaoTest {

    @Test

    public void test2() {

        // 第一步:获取sqlSession对象

        SqlSession sqlSession = MybatisUtils.getSqlSession();

        try {

            UserMapper userDao = sqlSession.getMapper(UserMapper.class);

            List<User2> userList = userDao.getUserInfoById("005", "刘亦菲");

            // 循环输出查询到的user信息

            userList.forEach(System.out::println);

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            // 关闭sqlSession

            sqlSession.close();

        }

    }

}

运行结果如下

二、生命周期和作用域

1、SqlSessionFactoryBuilder:用于创建SqlSessionFactory

这个类可以被实例化、使用和丢弃,一旦创建了 SqlSessionFactory,就不再需要它了

SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)

2、SqlSessionFactory:可以想象成数据库连接池

SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在

没有任何理由丢弃它或重新创建另一个实例,可以使用单例模式实现,SqlSessionFactory 的最佳作用域是应用作用域,即Application

3、SqlSession:可以看作连接到数据库连接池的一个请求

每个线程都应该有它自己的 SqlSession 实例,它的实例不是线程安全的,不能被共享

它的最佳的作用域是请求或方法作用域

用完之后需要关闭,否则资源会被占用

原文链接:https://blog.csdn.net/Decade0712/article/details/123613648
相关文章
最新更新