Mybatis——SqlSession的工作流程

1. 开启一个数据库访问会话---创建SqlSession对象:

MyBatis封装了对数据库的访问,把对数据库的会话和事务控制放到了SqlSession对象中。

2.为SqlSession传递一个映射的SQL语句的Statement Id和参数,然后返回结果:

SqlSession根据Statement ID, 在MyBatis配置对象Configuration中获取到对应的MappedStatement对象 调用MyBatis执行器来执行具体的操作。

MyBatis在初始化的时候,会将MyBatis的配置信息全部加载到内存中,使用Configuration实例来维护。

映射文件加载到内存中会生成n个对应的MappedStatement对象

key="net.onest.mapper.UserMapper.selectAllUsers" ,value为MappedStatement对象的形式维护到Configuration的一个Map类型的属性中。

编写代码进行测试

java 复制代码
public void insertUser() {
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        User user = new User();
        user.setUserName("lcs");
        user.setPassword("123456");

        int num = mapper.insertUser(user);
        System.out.println(num);
        System.out.println(user.getUserId());

        sqlSession.commit();
        sqlSession.close();
    }
相关推荐
星火开发设计5 分钟前
类模板:实现通用数据结构的基础
java·开发语言·数据结构·c++·html·知识
bugcome_com5 分钟前
# C# 变量作用域详解
开发语言·c#
阿里嘎多学长6 分钟前
2026-02-13 GitHub 热点项目精选
开发语言·程序员·github·代码托管
小宋102113 分钟前
Java 数据库访问 vs Python 数据库访问:JDBC vs ORM
java·数据库·python
汽车软件工程师00115 分钟前
vector autosar配置一个CAN接收报文,RTE层发现并未接收到信号,怎样查这个问题
开发语言·autosar
君爱学习22 分钟前
MySQL 分布式锁实现方案
java
寻寻觅觅☆27 分钟前
东华OJ-基础题-122-循环数(C++)-难度难
开发语言·c++
努力学编程呀(๑•ี_เ•ี๑)29 分钟前
【405】Not Allowed
java·vue.js·nginx·node.js
未既39 分钟前
docker & docker-compose离线部署步骤
java·docker
Zachery Pole1 小时前
JAVA_04_判断与循环
java·开发语言