MyBatis——XML配置文件

在MyBatis中,对于简单的SQL语句可以直接通过注解配置SQL语句,但是遇到复杂的SQL语句就不是那么方便了(比如说动态SQL),此时就需要使用XML配置文件配置SQL语句。

XML配置文件默认规则

有了XML配置文件之后,定义Mapper接口的时候就不需要再使用注解了,以下是XML配置文件的定义规则:

1.XML映射文件的名称必须和对应的Mapper接口完全、严格一致 ,并且XML映射文件必须和Mapper接口放置在相同的包下 (必须同包同名)。

名称完全一样,并且同包同名。

2.XML映射文件中的namespace属性必须和Mapper接口的全限定名完全一致。

namespace的属性和Mapper接口的全限定名一致。

3.XML映射文件中的SQL语句的id必须和Mapper接口中的方法名完全一致返回类型 也必须完全一致。

XML中需要引入头信息(约束),可以直接在Mybatis官方文档中拷贝:

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

SQL语句的id和Mapper中的方法名完全一致,返回类型也完全一致(注意,此处返回类型完全一致是指这些数据封装的对象是一致的,都是User实体对象)。

(注意,这里方法名下的红色波浪线不是报错,只是一个警告,因为这个项目是学习项目,里面有很多模块,模块中有很多同名的包和同名的类,idea在扫描的时候发现了这个问题,报了警告,实际上运行是没问题的。)

使用XML配置文件实现查询全部用户

在mapper接口中的代码十分简单:

csharp 复制代码
public List<User> selectAll();

XML文件中定义的SQL会查询user表中的每一个用户,然后将用户的所有字段根据User对象中的属性封装成User实体对象返回,当查询出多条用户记录时,MyBatis 框架会自动将这些一个个创建好的User实体对象封装成一个List集合。所以说方法直接返回List集合即可。

测试XML配置SQL是否成功:

csharp 复制代码
@Test
public void testSelectAll() {
    List<User> userList = userMapper.selectAll();
    for (User user : userList) {
        System.out.println(user);
    }
}
相关推荐
IT_陈寒8 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
兔子零10248 小时前
手把手教你在 Claude Code 中接入 DeepSeek-V4
后端
掌心向暖RPA自动化8 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭8 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
phenhorlin9 小时前
我做了个工具,让切换 Homebrew 镜像像切 npm 源一样简单
后端·shell
6959 小时前
两周浅学 RAG
后端
TeamDev9 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood10 小时前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven