MyBatis XML 配置文件:从配置规范到 CRUD 开发实践

个人主页♡喜欢做梦

欢迎 👍点赞 ➕关注 ❤️收藏 💬评论


目录

🌅前言

[🌅MyBatis XML配置文件的作用](#🌅MyBatis XML配置文件的作用)

🌅配置数据库连接字符串和MyBatis

🌄数据库配置

[application.yml 配置内容](#application.yml 配置内容)

[application.properties 配置内容](#application.properties 配置内容)

🌄MyBatis配置

[application.yml 配置内容](#application.yml 配置内容)

[application.properties 配置内容](#application.properties 配置内容)

🌅XML文件的核心组成成分

🌄MyBatis的xml固定格式

🌄文件创建

创建Mapper接口

创建xml文件

🌅增删查改操作

🌄增(Insert)

🌄删除(delete)

🌄查(select)

🌄改(update)


🌅前言

MyBatis的开发方式有两种:注解、XML。下来要将的就是XML,如果想要看MyBatis注解的,可以看我上一篇文章

🌅MyBatis XML配置文件的作用

MyBatis是一款持久层框架,他支持将SQL语句与Java代码分离,XML文件就是用来编写SQL语句,配置结果映射(ResultMap)等信息载体,让代码等清晰、维护更方便。

🌅配置数据库连接字符串和MyBatis

🌄数据库配置

application.yml 配置内容

javascript 复制代码
# 数据库连接配置
spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/mybatis_test?characterEncoding=utf8&useSSL=false
    username: root
    password: root
    driver-class-name: com.mysql.cj.jdbc.Driver

application.properties 配置内容

XML 复制代码
#驱动类名称
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#数据库连接的url
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/mybatis_test?characterEncoding=utf8&useSSL=false
#连接数据库的用户名
spring.datasource.username=root
#连接数据库的密码
spring.datasource.password=root
  • datasource.url: 数据库连接地址;
  • datasource.username:数据库登入用户名(例root);
  • datasource.password: 数据库密码(例root);
  • datasource.driver-class-name:MySqL驱动类。

🌄MyBatis配置

application.yml 配置内容

javascript 复制代码
mybatis:
  # 配置 mybatis xml 的文件路径,在 resources/mapper 创建所有表的 xml 文件
  mapper-locations: classpath:mapper/**Mapper.xml
   configuration: # 配置打印 MyBatis日志
     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
     map-underscore-to-camel-case: true #配置驼峰自动转换

application.properties 配置内容

XML 复制代码
# 配置 mybatis xml 的文件路径,在 resources/mapper 创建所有表的 xml 文件
mybatis.mapper-locations=classpath:mapper/**Mapper.xml
# 配置打印 MyBatis 日志
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
# 配置驼峰自动转换
mybatis.configuration.map-underscore-to-camel-case=true
  • mybatis.mapper-locations:指定映射文件(XML)位置。classpath:mapper/**Mapper.xml表示resource/mapper目录以下所有以Mapper.xml为结尾的文件;
  • mybatis.configuration.log-impl:配置MyBatis的日志实现;
  • mybatis.configuration.map-underscore-to-camel-case:开启驼峰命名。

🌅XML文件的核心组成成分

以映射文件(UserInfoMapper.xml)为例

🌄MyBatis的xml固定格式

javascript 复制代码
<?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="对应的Mapper接口的全限定类名">
    
</mapper>
  • 示例对应的Mapper接口的全限定类名:
javascript 复制代码
<mapper namespace="com.mybatis.demo.mapper.UserInfoXMLMapper">
      <!-- SQL语句   -->
</mapper>

🌄文件创建

创建Mapper接口

java 复制代码
@Mapper
public interface UserInfoXMLMapper {
}

创建xml文件

🌅增删查改操作

🌄增(Insert)

UserInfoMapper.xml

XML 复制代码
 <insert id="insertUserInfo" parameterType="com.mybatis.demo.model.UserInfo">
        insert into user_info(username,password,age) values (#{username},#{password},#{age})
    </insert>
  • <insert>的id必须与UserInfoXMLMapper中的insertUserInfo一致;
  • parameType:入参类型(可省略),如果要写,要写全类名。

UserInfoXMLMapper接口

javascript 复制代码
@Mapper
public interface UserInfoXMLMapper {
       Integer insertUserInfo(UserInfo userInfo);
}

测试

javascript 复制代码
@SpringBootTest
class UserInfoXMLMapperTest {
     @Autowired
     private UserInfoXMLMapper userInfoXMLMapper;
    @Test
    void insertUserInfo() {
        UserInfo userInfo=new UserInfo();
        userInfo.setUsername("张三");
        userInfo.setPassword("123");
        userInfo.setAge(13);

        System.out.println(userInfoXMLMapper.insertUserInfo(userInfo));
    }
}

结果

添加自增主键

javascript 复制代码
 </insert>
    <insert id="insertUserInfo2" parameterType="com.mybatis.demo.model.UserInfo" useGeneratedKeys="true" keyProperty="id">
        insert into user_info(username,password,age) values (#{username},#{password},#{age})
    </insert>

🌄删除(delete)

UserInfoMapper.xml

javascript 复制代码
<delete id="deleteUser">
        delete from user_info where username=(#{username})
    </delete>

UserInfoXMLMapper接口

javascript 复制代码
Integer deleteUser(UserInfo userInfo);

测试

javascript 复制代码
@Test
    void deleteUser() {
        UserInfo userInfo=new UserInfo();
        userInfo.setUsername("张三");
        userInfoXMLMapper.deleteUser(userInfo);
    }

结果

🌄查(select)

UserInfoMapper.xml

javascript 复制代码
    <select id="selectUserById" resultType="com.mybatis.demo.model.UserInfo">
        select username,password,age,phone from user_info where id=(#{id})
    </select>
  • resultType:返回值类型,如果缺少,那么参数占位符写法不规范。

UserInfoXMLMapper接口

javascript 复制代码
UserInfo selectUserById(Integer id);

测试

javascript 复制代码
@Test
    void selectUserById() {
        userInfoXMLMapper.selectUserById(1);
    }

结果

🌄改(update)

UserInfoMapper.xml

javascript 复制代码
Integer updateUser(String username,Integer id);

UserInfoXMLMapper接口

javascript 复制代码
<update id="updateUser">
        update user_info set username=#{username} where id=#{id}
    </update>

测试

javascript 复制代码
 @Test
    void updateUser() {
        userInfoXMLMapper.updateUser("lisi",2);
    }

结果

相关推荐
wuminyu14 分钟前
专家视角看Java字节码加载与存储指令机制
java·linux·c语言·jvm·c++
callJJ2 小时前
Spring Data Redis 两种编程模型详解:同步 vs 响应式
java·spring boot·redis·python·spring
wbs_scy2 小时前
Linux线程同步与互斥(三):线程同步深度解析之POSIX 信号量与环形队列生产者消费者模型,从原理到源码彻底吃透
java·开发语言
jinanwuhuaguo4 小时前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
xmjd msup4 小时前
spring security 超详细使用教程(接入springboot、前后端分离)
java·spring boot·spring
952365 小时前
SpringBoot统一功能处理
java·spring boot·后端
Lyyaoo.5 小时前
优惠券秒杀业务分析
java·开发语言
消失的旧时光-19435 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法
勿忘初心12215 小时前
Java 国密 SM4 加密工具类实战(Hutool + BouncyCastle)|企业级数据加密 + 兼容 JDK8
java·数据安全·数据加密·后端开发·企业级开发·国密 sm4
庞轩px5 小时前
第8篇:原子类与CAS底层原理——无锁并发的实现
java·cas·乐观锁·aba·无锁编程·自旋