Mybatis使用xml方式配置(四)结果映射resultMap

相关章节:
Mybatis使用xml方式配置
Mybatis使用xml方式配置(二)
Mybatis使用xml方式配置(三)

官网地址:https://mybatis.org/mybatis-3/zh/configuration.html

1. 作用域(Scope)和生命周期

  • SqlSessionFactoryBuilder:这个类一旦创建了 SqlSessionFactory,就不再需要它了。因此 SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。
  • SqlSessionFactory:一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。因此 SqlSessionFactory 的最佳作用域是应用作用域。 有很多方法可以做到,最简单的就是使用单例模式或者静态单例模式。
  • SqlSession:每个线程都应该有它自己的 SqlSession 实例。SqlSession的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。换句话说,每次收到 HTTP 请求,就可以打开一个 SqlSession,返回一个响应后,就关闭它。 这个关闭操作很重要!!!

2. 结果映射resultMap

resultMap元素是 MyBatis中最重要最强大的元素。我们在UserMapper.xml中查询用户的时候,返回resultType的时候,如:

<select id="findUserInfoByID" parameterType="int" resultType="com.weizu.pojo.UserInfo">
    select * from userinfo where userid = #{userid}
</select>

MyBatis会在幕后自动创建一个ResultMap,再根据属性名来映射列到JavaBean 的属性上。比如这种实现,在UserMapper.xml文件中:

<resultMap id="mapUserInfo" type="com.weizu.pojo.UserInfo">
    <id property="userid" column="userid" />
    <result property="username" column="username"/>
    <result property="passwd" column="passwd"/>
</resultMap>

<select id="findUserInfoByID" parameterType="int" resultMap="mapUserInfo">
    select * from userinfo where userid = #{userid}
</select>

测试:

@org.junit.Test
public void find(){
    SqlSession sqlSession = MybatisUtils.getSqlSession();
    UserDao mapper = sqlSession.getMapper(UserDao.class);

    // 查找,传入基本类型
    UserInfo userInfoByID = mapper.findUserInfoByID(234);
    System.out.println(userInfoByID); // success
}

在这里插入图片描述
同时,使用resultMap可以映射pojo实体对象和数据库表字段不一致情况;当然,最简单的解决方式是在sql语句中使用别名来解决映射字段名不一致问题;
同时,使用resultMap也可以解决多表查询时候的映射问题;也就是文档中的高级结果映射


https://www.bilibili.com/video/BV1NE411Q7Nx?p=9
https://www.bilibili.com/video/BV1NE411Q7Nx?p=10

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦否

文章对你有用?不妨打赏一毛两毛

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值