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();
    }
相关推荐
lcu11113 小时前
Java 学习38:ArrayList 类
java
q***25113 小时前
Spring Boot 集成 Kettle
java·spring boot·后端
筱顾大牛13 小时前
IDEA使用Gitee来创建远程仓库
java·gitee·intellij-idea
司铭鸿13 小时前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
懂得节能嘛.13 小时前
【SDK开发实践】从Java编码到阿里云制品仓库部署
java·阿里云·maven
wavemap13 小时前
先到先得:免费订阅一年ChatGPT Go会员
开发语言·chatgpt·golang
空空kkk13 小时前
SpringMVC——异常
java·前端·javascript
重整旗鼓~14 小时前
1.大模型使用
java·语言模型·langchain
m***D28614 小时前
JavaScript在Node.js中的内存管理
开发语言·javascript·node.js
我叫张小白。14 小时前
JavaScript现代语法梳理:ES6+核心特性详解
开发语言·javascript·typescript·es6