Mybatis之作用域(Scope)和生命周期-解决属性名和字段名不一致的问题&ResultMap结果集映射

生命周期类别是至关重要的,因为错误的使用会导致非常严重的并发问题

SqlSessionFactoryBuilder

  • 一旦创建了 SqlSessionFactory,就不再需要它了。
  • 局部变量

SqlSessionFactory

  • 说白了就是可以想象为:数据库连接池
  • 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例
  • 因此SqlSessionFactory 的最佳作用域是应用作用域。
  • 最简单的就是使用单例模式或者静态单例模式。

SqlSession

  • 连接到池的一个请求!
  • SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
  • 用完之后感觉关闭,否则资源被占用!

一个池子有多个线程,每一个线程都是独享的,不能够共享。每一个SqlSession 都会去连接Mapper,这里面的每一个Mapper,就代表一个具体的业务!(SQL)

参考:

plain 复制代码
https://mybatis.org/mybatis-3/zh_CN/getting-started.html

问题

数据库中的字段

新建一个项目,拷贝之前的,测试实体类字段不一致的!

java 复制代码
public class user {
    private int id;
    private String name;
    private String password;

测试出现问题

java 复制代码
    select * from mybatis.user where id=#{id};
//类型处理器
    select id,name,pwd from mybatis.user where id=#{id};

解决方法:

  • 起别名

UserMapper.xml 中

xml 复制代码
<select id="getUserById" parameterType="int" resultType="user">
        select id,name,pwd as password from mybatis.user where id=#{id};
</select>

resultMap

结果集映射

xml 复制代码
id	name	pwd
id	name	password

UserMapper.xml 中

xml 复制代码
    <!--     结果集映射
    id是属性,用来给应用的,type指定类名-->
    <resultMap id="UserMap" type="user">
        <!--列column指的是数据库中的字段,属性property指的是实体类中的属性-->
        <result column="id" property="id"/>
        <result column="name" property="name"/>
        <!--数据库中的列是pwd,实体类中的属性是password,进行结果集映射-->
        <result column="pwd" property="password"/>
    </resultMap>
    
    <!--<select id="对应UserMapper的方法" resultType="实体类">-->
    <select id="getUserById" resultMap="UserMap">
            select * from mybatis.user where id=#{id};
    </select>
  • <font style="color:rgb(221, 17, 68);background-color:rgb(247, 247, 249);">resultMap</font> 元素是 MyBatis 中最重要最强大的元素
  • ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。
  • <font style="color:rgb(221, 17, 68);background-color:rgb(247, 247, 249);">ResultMap</font> 的优秀之处------你完全可以不用显式地配置它们
  • 如果这个世界总是这么简单就好了。

参考:

plain 复制代码
官方文档:https://mybatis.org/mybatis-3/zh_CN/sqlmap-xml.html
相关推荐
.千余17 分钟前
【C++】C++ set 与 multiset 完全指南:关联式容器入门
开发语言·c++·笔记·学习·其他
c++之路3 小时前
CMake 系列教程(二):基础命令详解
开发语言·c++
阿维的博客日记6 小时前
Hippo4j 线程池监控平台部署手册
java·spring boot·后端
南境十里·墨染春水7 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
C+++Python8 小时前
详细介绍一下Java泛型的通配符
java·windows·python
pixcarp8 小时前
知识库系统的内容资产闭环怎么设计
服务器·数据库·后端·golang
JosieBook9 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
加号39 小时前
【C#】 文件与目录管理:创建、删除操作的技术解析
开发语言·c#
diving deep9 小时前
脚本速览-python
开发语言·python
一生了无挂10 小时前
Java处理JSON技巧教学(从基础到高阶实战全覆盖)
java·开发语言·json