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();
    }
相关推荐
MoonBit月兔13 小时前
报名仅剩 3 天|MoonBit 软件合成挑战赛已有数十个项目参赛!
开发语言·人工智能·编程·moonbit
洛阳泰山13 小时前
开源智能体搭建平台MaxKB4j 技术文档
java·开源·llm·springboot·agent·rag·langchain4j
我命由我1234513 小时前
Android 开发 - UriMatcher(一个 URI 分类器)
android·java·java-ee·kotlin·android studio·android-studio·android runtime
sinat_2554878113 小时前
为 System.out 编写我们自己的包装类
java·开发语言·算法
a8a30213 小时前
Springboot中CommandLineRunner的用法以及执行顺序的控制
java·spring boot·spring
代码探秘者13 小时前
【大模型应用】1.了解RAG
java·人工智能·python·spring
蓝天星空13 小时前
跨平台开发语言对比
开发语言·c#·.net
sevenlin13 小时前
Spring Boot 经典九设计模式全览
java·spring boot·设计模式
Barkamin13 小时前
快速排序非递归实现
java·算法·排序算法
salipopl13 小时前
Spring Boot 集成 MyBatis 全面讲解
spring boot·后端·mybatis