MyBatis原理剖析(二)

上一章节我们聊了聊JDBC的缺点以及mybatis的基本框架,本章我们从mapper配置文件入手来解析mybatis

我们知道在mybatis中由于数据库连接的配置文件不经常更改,而sql的配置文件则总是要去更改因此对于不同类型的配置文件采用了隔离的机制,对于系统配置文件用**sqlMapConfig**来进行配置对于sql语句的配置文件则采用mapper配置文件进行配置。

mapper配置文件:

对于mapper配置文件来说是用来存储sql语句的,那么所有的sql语句都放在一个mapper配置文件中吗?答案肯定是否定的。对于mapper来说往往是一个service业务有着自己的mapper配置文件

如上图所示,product业务有着自己的mapper,user业务也有着自己的mapper。这样使得mapper之间相互隔离每个mapper专注于一个业务进行服务。那么这些mapper内部是如何配置的呢?下面我们看看userMapper的代码。

XML 复制代码
<mapper namespace="com.example.mapper.UserMapper">
  <!-- 查询用户 -->
  <select id="selectUserById" parameterType="Long" resultType="xx.xx.xx.User">
    SELECT * FROM users WHERE id = #{id}
  </select>

  <!-- 插入用户 -->
  <insert id="insertUser" parameterType="User">
    INSERT INTO users (username, email, age)
    VALUES (#{username}, #{email}, #{age})

   </insert>

</mapper>

我们可以看到最外层是一个mapper标签,这个mapper标签的主要作用就是区分不同的mapper文件,mapper标签含有一个namespace的属性,不同的mapper中的namespace的值不同这样就实现了相互隔离的机制。我们继续看内部含有了一个select标签和一个insert标签这两个标签每一个都将会被映射为一个mappedStatement对象用来对应每一个sql语句,继续看这两个标签内部我们发现都含有id,这个id就是给当前sql起了一个名字为了能够准确的定位到当前sql。并且select标签和insert标签都标志着sql不同的执行类型。同时我们之前说到过mybatis解决了JDBC执行sql后返回结果需要手动封装的问题,在上述select标签内部的resultType这个属性则是指明返回的数据类型,通过resultType所指向的类全路径使得返回数据能够映射到指定的返回类型中去。同时在jdbc中是用?来表示占位符,但是在mybatis则是通过#{}来进行占位符,通过parameterType来说明参数的映射类型是什么样的。parameterType和resultType本质都是通过反射来将数据进行映射出来的。

总的来说:并不是所有的sql语句都写到一个mapper配置文件中去,而是将不同的sql根据业务放在不同的mapper中去,同时每个mapper有着自己的命名空间实现mapper之间的隔离,mapper中的sql语句都是由一个标签进行包裹用来映射为一个mappedStatement对象,每个标签都有着自己的id。并且通过标签的parameterType属性和resultType属性分别用来标志反射映射的类型。

sqlMapConfig配置文件:

对于**sqlMapConfig** 配置文件来说则是用来配置sql的连接的,同时在这个配置文件内部还含有mapper配置文件的地址,也就是说只要加载**sqlMapConfig就能够读取到所有的mapper文件**

也是使用反射的机制将配置文件中的属性一个个映射到类属性中

XML 复制代码
<configuration>
  <!-- 环境配置 -->
  <environments default="development">
    <environment id="development">
      <transactionManager type="JDBC"/>
      <dataSource type="POOLED">
        <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/test?useSSL=false"/>
        <property name="username" value="root"/>
        <property name="password" value="password"/>
      </dataSource>
    </environment>
  </environments>

  <!-- 注册Mapper -->
  <mappers>
    <mapper resource="mapper/UserMapper.xml"/> <!-- 注册Mapper文件 -->
  </mappers>
</configuration>

对于**sqlMapConfig**配置文件和mapper配置文件则是分别映射到Configuration和MappedStatement对象中后续将会介绍这两个对象的属性。

相关推荐
nbsaas-boot8 分钟前
如何进行 Vibe Coding:从“灵感驱动”到“可交付工程”的方法论
java·ai编程
我是黄骨鱼9 分钟前
【零基础学数据库|第二篇】MySql启动!!!
数据库·mysql
陌上丨10 分钟前
什么是Redis的大Key和热Key?项目中一般是怎么解决的?
数据库·redis·缓存
Remember_99311 分钟前
Spring 事务深度解析:实现方式、隔离级别与传播机制全攻略
java·开发语言·数据库·后端·spring·leetcode·oracle
小园子的小菜11 分钟前
深入剖析HBase HFile原理:文件结构、Block协作与缓存机制
数据库·缓存·hbase
roman_日积跬步-终至千里16 分钟前
【Java并发】用 JMM 与 Happens-Before 解决多线程可见性与有序性问题
java·开发语言·spring
空空kkk16 分钟前
SSM项目练习——hami音乐(三)
java·数据库
好奇的菜鸟23 分钟前
Ubuntu 18.04 启用root账户图形界面登录指南
数据库·ubuntu·postgresql
天桥下的卖艺者24 分钟前
使用R语言编写一个生成金字塔图形的函数
开发语言·数据库·r语言
爬山算法24 分钟前
Hibernate(78)如何在GraphQL服务中使用Hibernate?
java·hibernate·graphql