【JavaWeb】Day50.Mybatis的XML配置文件

XML配置文件规范

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

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

  1. XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)

  2. XML映射文件的namespace属性为Mapper接口全限定名一致

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

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

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

XML配置文件实现

第1步:创建XML映射文件

第2步:编写XML映射文件

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

复制代码
~~~xml
<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接口全限定名

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

复制代码
~~~xml
<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="com.itheima.mapper.EmpMapper">

    <!--查询操作-->
    <select id="list" resultType="com.itheima.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>
~~~

运行测试类,执行结果:

MybatisX的使用

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

MybatisX的安装:

可以通过MybatisX快速定位:

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

相关推荐
hadage23314 小时前
--- redis 常见问题 ---
数据库·redis·mybatis
浪潮IT馆14 小时前
Tomcat运行war包的问题分析与解决步骤
java·tomcat
_院长大人_15 小时前
MyBatis Plus 分批查询优化实战:优雅地解决 IN 参数过多问题(实操)
java·mybatis
烤麻辣烫18 小时前
黑马程序员苍穹外卖后端概览
xml·java·数据库·spring·intellij-idea
暗碳18 小时前
安卓abx二进制xml文件转换普通xml文件
android·xml
5***b9718 小时前
SpringBoot(整合MyBatis + MyBatis-Plus + MyBatisX插件使用)
spring boot·tomcat·mybatis
一直都在57220 小时前
手写tomcat(1):Socket
java·tomcat
jinxinyuuuus21 小时前
文件格式转换工具:XLSX的XML流式解析、数据类型推断与CSV编码规范
xml
杀死那个蝈坦21 小时前
MyBatis-Plus 使用指南
java·kafka·tomcat·mybatis—plus
小坏讲微服务1 天前
SpringBoot4.0整合Scala完整使用
java·开发语言·spring boot·后端·scala·mybatis