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
相关推荐
草莓熊Lotso1 小时前
Linux 基础 IO 初步解析:从 C 库函数到系统调用,理解文件操作本质
linux·运维·服务器·c语言·数据库·c++·人工智能
梵刹古音1 小时前
【C语言】 字符数组相关库函数
c语言·开发语言·算法
Cx330❀2 小时前
从零实现Shell命令行解释器:原理与实战(附源码)
大数据·linux·数据库·人工智能·科技·elasticsearch·搜索引擎
微风中的麦穗7 小时前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_949146538 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术8 小时前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学8 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
岁岁种桃花儿8 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
毕设源码-朱学姐8 小时前
【开题答辩全过程】以 基于JavaWeb的网上家具商城设计与实现为例,包含答辩的问题和答案
java
jiunian_cn9 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法