Mydatis对数据库的增删改查

本文详细介绍了MyBatis的工作原理,包括SqlSessionFactory的创建、SqlSession对象的使用,以及如何配置mybatis_conf.xml和properties文件。通过示例展示了如何进行数据库的增删改查操作,包括Teacher接口和实体类的创建,以及Mapper文件的编写和测试。同时,文章还涵盖了MyBatis的多表查询,创建BookMapper接口、Book和BookType实体类,以及Mapper XML文件的配置和测试过程。
摘要由CSDN通过智能技术生成

MyBatis工作原理

读取 MyBatis 配置文件 mybatis-config.xmlo mybatis-config.xml 作为 MyBatis 的全局配 置文件,配置了 MyBatis 的运行环境等信息,其中主要内容是获取数据库连接。
加载映射文件 Mapper.xmlo Mapper.xml 文件即 SOL 映射文件,该文件中配置了操作 数据库的 SOL 语句,需要在 mybatis-config.xml 中加载才能执行。 mybatis-config.xml 可以加 载多个配置文件,每个配置文件对应数据库中的一张表。
构建会话工厂。 通过 MyBatis 的环境等配置信息构建会话工厂 SqlSessionFactory。
创建 SqlSession 对象。 由会话工厂创建 SqlSession 对象,该对象中包含了执行 SOL 的所有方法。
MyBatis 底层定义了一个 Executor 接口来操作数据库,它会根据 SqlSession 传递的参 数动态地生成需要执行的 SOL 语句,同时负责查询缓存的维护。
在 Executor 接口的执行方法中,包含一个 MappedStatement 类型的参数, 该参数是对映射信息的封装 ,用于存储要映射的 SOL 语句的 id、参数等。 Mapper.xml 文件中一个 SOL 对应一个. MappedStatement 对象 , SOL 的 id 即是 MappedStatement 的 id。
7.输入参数映射。 在执行方法时, MappedStatement 对象会对用户执行 SOL 语句的输入 参数进行定义(可以定义为 Map、List 类型、基本类型和 POJO 类型 ), Executor 执行器会通过 MappedStatement 对象在执行 SOL 前,将输入的 Java 对象映射到 SOL 语句中 。 这里对输入参 数的映射过程就类似于 JDBC 编程中对 preparedStatement 对象设置参数的过程。
输出结果映射。 在数据库中执行完 SOL 语句后, MappedStatement 对象会对 SOL 执 行输出的结果进行定义(可以定义为 Map 和List 类型、基本类型、 POJO 类型 ), Executor 执行 器会通过 MappedStatement 对象在执行 SOL 语句后,将输出结果映射至 Java 对象中。 这种将 输出结果映射到 Java 对象的过程就类似于 JDBC 编程中对结果的解析处理过程。
通过上面对 MyBatis 框架执行流程的讲解,相信读者对 MyBatis 框架已经有了一个初步的了 解。 对于初学者来说,上面所讲解的内容可能不会完全理解,现阶段也不要求读者能完全理解, 这里讲解 MyBatis 框架的执行过程是为了方便后面程序的学习。 在学习完 MyBatis 框架后,读者 自然就会明白上面所讲解的内容了 。

SqlSessionFactory

SqlSessionFactory 是 MyBatis 框架中十分重要的对象,它是单个数据库映射关系经过编译 后的内存镜像,其主要作用是创建 SqlSession。
SqlSessionFactory 对象的实例可以过SqlSessionFactoryBuilder 对象来构建,而 SqlSessionFactoryBuilder 则可以通过 XML 配置文件 或一个预先定义好的 Configuratiori 实例构建出 SqlSessionFactory 的实例。
Sq ISessionFactory 对象是线程安全的,它一旦被创建,在整个应用执行期间都会存在。 如果我 们多次地创建同一个数据库的 SqlSessionFactory,那么此数据库的资源将很容易被耗尽。 为了解决 此问题,通常每一个数据库都会只对应一个 SqlSessionFactory,所以在构建 SqlSessionFactory 实例时,建议使用单列模式。

SqlSession

SqlSession 是 MyBatis 框架中另一个重要的对象,它是应用程序与持久层之间执行交互操 作的一个单线程对象,其主要作用是执行持久化操作。 SqlSession 对象包含了数据库中所有执 行 SQL 操作的方法,由于其底层封装了 JDBC 连接,所以可以直接使用其实例来执行己映射的 SQL 语句。
每一个线程都应该有一个自己的 SqlSession 实例,并且该实例是不能被共享的。 同时, SqlSession 实例也是线程不安全的,因此其使用范围最好在一次请求或一个方法中,绝不能将其放 在一个类的静态字段、实例字段或任何类型的管理范围(如 Servlet 的 HttpSession )中使用。 使用 完 SqlSession 对象之后,要及时地关闭它,通常可以将其放在 finally 块中关闭。
SqlSession 对象中包含了很多方法,其常用方法如下所示。
• T selectOne ( String statement ); 查询方法。 参数 statement 是在配置文件中定义的元素的 id。 使用该方法后,会返 回执行 SOL 语句查询结果的一条泛型对象。
• T selectOne ( String statement, Object parameter ); 查询方法。 参数 statement 是在配置文件中定义的<selecb元素的 id , parameter 是查询所 需的参数。 使用该方法后,会返回执行 SOL 语句查询结果的一条泛型对象。
• List selectList ( String statement ); 查询方法。 参数 statement 是在配置文件中定义的元素的 id。 使用该方法后,会返 回执行 SOL 语句查询结果的泛型对象的集合。
• List selectList ( String statement, Object parameter ); 查询方法。 参数 statement 是在配置文件中定义的<selecb元素的 id , parameter 是查询所 需的参数。 使用该方法后,会返回执行 SOL 语句查询结果的泛型对象的集合。
• List selectList ( String statement, Object parameter, RowBounds rowBounds ); 查询方法。 参数 statement 是在配置文件中定义的元素的 id , parameter 是查询所 需的参数, rowBounds 是用于分页的参数对象。 使用该方法后,会返回执行 SOL 语句查询结果 的泛型对象的集合。
• void select ( String statement, Object parameter, ResultHandler handler ); 查询方法。 参数 statement 是在配置文件中定义的<selecb元素的 id , parameter 是查询所 需的参数, ResultHandler 对象用于处理查询返回的复杂结果集,通常用于多表查询。
• int insert ( String statement ); 插入方法。 参数 statement 是在配置文件中定义的<inserb元素的 id。 使用该方法后,会返 回执行 SOL 语句所影响的行数。
• int insert ( String statement, Object parameter ); 插入方法。 参数 statement 是在配置文件中定义的<inserb元素的 id , parameter 是插入所 需的参数。 使用该方法后,会返回执行 SOL 语句所影响的行数。
• int update ( String statement ); 更新方法。 参数 statement 是在配置文件中定义的元素的 id。 使用该方法后,会 返回执行 SOL 语句所影响的行数。
• int update ( String statement, Object parameter ); 更新方法。 参数 statement 是在配置文件中定义的元素的 id , parameter 是更新 所需的参数。 使用该方法后,会返回执行 SOL 语句所影响的行数。
• int delete ( String statement ); 删除方法。 参数 statement 是在配置文件中定义的元素的 id。 使用该方法后,会返 回执行 SOL 语句所影响的行数。
• int delete ( String statement, Object parameter ); 删除方法。 参数 statement 是在配置文件中定义的元素的 id , parameter 是删除所 需的参数。 使用该方法后,会返回执行 SOL 语句所影响的行数。

配置mybatis_conf.xml文件

<configuration>
    <!-- 引入外部的properties文件,只能引入一个 -->
    <properties resource="jdbc.properties" />
    
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="false"/>
    </settings>
    
    <!-- 定义类型别名(全局),在所有的Mapper.xml中都可以用 -->
    <typeAliases>
        <typeAlias type="com.lanou3g.mybatis.bean.Teacher" alias="Teacher" />
        <typeAlias type="com.lanou3g.mybatis.bean.Student" alias="Student" />
    </typeAliases>
    <!-- 配置多套环境的数据库连接参数(如:开发环境、生产环境) -->
    <environments default="zhangguosheng">

    <environment id="zhangguosheng">
        <!-- 事务管理器:
            MANAGED: 这个配置就是告诉mybatis不要干预事务,具体行为依赖于容器本身的事务处理逻辑。
            JDBC: 这个配置就是直接使用了 JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
         -->
        <transactionManager type="MANAGED"/>
        <dataSource type="POOLED">
            <property name="driver" value="${jdbc.driver}"/>
            <property name="url" value="${jdbc.url}"/>
            <property name="username" value="${jdbc.user}"/>
            <property name="password
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值