MyBatis的XML配置文件

142 阅读2分钟

MyBatis中文官网:

www.mybatis.cn/

Mybatis的开发有两种方式:

  1. 注解
  2. XML

XML配置文件规范

使用Mybatis的注解方式,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句,也就是将SQL语句写在XML配置文件中。

在Mybatis中使用XML映射文件方式开发,需要符合一定的规范:

  1. XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)
  2. XML映射文件的namespace属性为Mapper接口全限定名一致
  3. XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致。

image-20221212153529732.png

<select>标签:就是用于编写select查询语句的。

resultType属性,指的是查询返回的单条记录所封装的类型。

XML配置文件实现

第1步:创建XML映射文件

图片.png

创建一个xml的模版文件并命名为 new mapper,这样在以后可以直接使用这个模版 图片.png

可以直接从官网复制, www.mybatis.cn/mybatis/32.…

图片.png

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper  
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
    "https://mybatis.org/dtd/mybatis-3-mapper.dtd">  
<!-- namespace等于mapper接口类的全限定名,这样实现对应 -->  
<mapper namespace="">  
  
</mapper>

创建EmpMapper.xml,注意文件名需要和Mapper接口一致

图片.png

图片.png

第2步:编写XML映射文件

xml映射文件中的dtd约束,直接从mybatis官网复制即可

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="">
 
</mapper>

配置:XML映射文件的namespace属性为Mapper接口全限定名

图片.png

配置:XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致

图片.png

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace等于mapper接口类的全限定名,这样实现对应 -->
<mapper namespace="com.yantong.mapper.EmpMapper">

    <!--查询操作-->
    <select id="list" resultType="com.yantong.pojo.Emp">
        select * from emp
        where name like concat('%',#{name},'%')
        and gender = #{gender}
        and entrydate between #{begin} and #{end}
        order by update_time desc
    </select>
</mapper>

运行测试类,执行结果:

图片.png

MyBatisX的使用

MybatisX是一款基于IDEA的快速开发Mybatis的插件,为效率而生。

MybatisX的安装:

image-20221213120923252.png

可以通过MybatisX快速定位:

image-20221213121521406.png

学习了Mybatis中XML配置文件的开发方式了,大家可能会存在一个疑问:到底是使用注解方式开发还是使用XML方式开发?

官方说明:mybatis.net.cn/getting-sta…

image-20220901173948645.png

结论: 使用Mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句。