Mybatis中执行Sql的执行过程

MyBatis中执行SQL的过程可以分为以下几个步骤:

  1. 解析配置文件:在运行时,MyBatis会加载并解析配置文件(通常为mybatis-config.xml),获取数据库连接信息、映射文件等。

  2. 创建SqlSessionFactory:MyBatis使用SqlSessionFactory来创建SqlSession对象。SqlSessionFactory是一个线程安全的对象,应该在应用程序启动时创建一次,并在整个应用程序生命周期内重复使用。

  3. 创建SqlSession:应用程序通过SqlSessionFactory创建SqlSession对象。SqlSession是一个轻量级的非线程安全对象,用于执行SQL语句和管理事务。

  4. 获取Mapper接口:应用程序通过SqlSession获取Mapper接口的实现类。Mapper接口定义了SQL语句和Java方法之间的映射关系,MyBatis会根据这些映射关系生成SQL语句并执行。

  5. 执行SQL语句:应用程序调用Mapper接口的方法时,MyBatis会根据映射文件中的配置信息,生成对应的SQL语句,并将参数传递给数据库执行。MyBatis支持多种SQL语句,如查询、插入、更新、删除等。

  6. 处理结果集:当数据库执行完SQL语句并返回结果时,MyBatis会将查询结果映射到Java对象中。根据映射文件中的配置规则,MyBatis会将数据库查询结果的列映射到Java对象的属性上,从而方便应用程序对数据的处理和使用。

  7. 提交事务:如果应用程序开启了事务管理,MyBatis会在执行完SQL语句后提交事务。如果发生异常或事务回滚,MyBatis会撤销之前的操作,并关闭数据库连接。

  8. 关闭SqlSession:当应用程序完成对数据库的操作后,需要手动关闭SqlSession对象。这样可以释放资源,避免内存泄漏等问题。

java 复制代码
    @Test
    public void testInsert() throws IOException {
//        获取核心配置文件的输入流
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
//        获取SqlSessionFactoryBuilder对象
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//        获取SqlSessionFactoryBuilder对象
        SqlSessionFactory build = sqlSessionFactoryBuilder.build(is);
//        获取sql的会话对象sqlSession,是Mybatis提供操作数据库的对象
        SqlSession sqlSession = build.openSession(true);
//        获取UserMapper的代理实现类对象
//        底层会给我创建UserMapper的实现类,然后返回
//        TODO 使用了代理模式,创建了UserMapper的实现类
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//        TODO 执行原理,根据Id查找,然后找到其映射的对象,然后进行实现 sqlSession.insert()
//        int result = sqlSession.insert("com.mybatis.mapper.UserMapper.insertUserOne");


//        User user = new User(null, "abc", "123456", 18);
        int result = mapper.insertUserOne();
        System.out.println(mapper instanceof UserMapper);

        System.out.println("result = " + result);
//        提交事务
//        如果不提交事务,那么显示看不到效果的,事务还没有提交
//        sqlSession.commit();
//        关闭sqlSession
        sqlSession.close();

    }
相关推荐
失败又激情的man8 分钟前
python爬虫之数据存储
前端·数据库·python
遗忘妳12 分钟前
mysql高可用
数据库·mysql
小灰灰搞电子25 分钟前
Qt多线程访问同一个数据库源码分享(基于Sqlite实现)
数据库·qt·sqlite
麓殇⊙28 分钟前
redis--黑马点评--Redisson快速入门
数据库·redis·缓存
爱思德学术33 分钟前
DBLP数据库是什么?
数据库
onlooker666635 分钟前
Go 语言底层(四) : 深入 Context 上下文
开发语言·数据库·golang
岁忧37 分钟前
MySQL中【正则表达式】用法
数据库·mysql·正则表达式
浠寒AI2 小时前
PostgreSQL 与 SQL 基础:为 Fast API 打下数据基础
数据库·sql·postgresql
金州饿霸2 小时前
MySQL--慢查询日志、日志分析工具mysqldumpslow
数据库·mysql
zhujilisa2 小时前
MySql中的锁
数据库·mysql