Mybatis的添加和修改功能

MyBatis 添加功能

使用 MyBatis 实现添加功能通常涉及以下几个步骤:

定义插入操作的 SQL 语句,可以在 Mapper XML 文件中编写 insert 语句或者在接口中使用注解方式:

XML 方式示例:

xml 复制代码
<insert id="insertUser" parameterType="com.example.User">
    INSERT INTO user(name, age) VALUES(#{name}, #{age})
</insert>
 

接口注解方式示例:

java 复制代码
@Insert("INSERT INTO user(name, age) VALUES(#{name}, #{age})")
int insertUser(User user);
 

在 Service 层调用 Mapper 方法:

java 复制代码
User user = new User();
user.setName("张三");
user.setAge(25);
userMapper.insertUser(user);
 

如果需要获取自增主键,可以配置 useGeneratedKeys:

xml 复制代码
<insert id="insertUser" parameterType="com.example.User" 
        useGeneratedKeys="true" keyProperty="id">
    INSERT INTO user(name, age) VALUES(#{name}, #{age})
</insert>
 

MyBatis 修改功能

修改功能与添加类似,需要使用 update 语句:

XML 方式示例:

xml 复制代码
<update id="updateUser" parameterType="com.example.User">
    UPDATE user SET name=#{name}, age=#{age} WHERE id=#{id}
</update>
 

接口注解方式示例:

java 复制代码
@Update("UPDATE user SET name=#{name}, age=#{age} WHERE id=#{id}")
int updateUser(User user);
 

Service 层调用示例:

java 复制代码
User user = userMapper.getUserById(1);
user.setName("李四");
user.setAge(30);
userMapper.updateUser(user);
 

动态更新可以使用 set 标签:

xml 复制代码
<update id="updateUser" parameterType="com.example.User">
    UPDATE user
    <set>
        <if test="name != null">name=#{name},</if>
        <if test="age != null">age=#{age},</if>
    </set>
    WHERE id=#{id}
</update>
 

批量操作可以使用 foreach 标签:

xml 复制代码
<insert id="batchInsert" parameterType="java.util.List">
    INSERT INTO user(name, age) VALUES
    <foreach collection="list" item="item" separator=",">
        (#{item.name}, #{item.age})
    </foreach>
</insert>
 

总结:

MyBatis 的"添加(INSERT)"和"修改(UPDATE)"套路相同

  1. 写接口方法

  2. 写 XML(或注解)SQL

  3. 调用完必须提交事务sqlSession.commit()),否则数据不会真正进库。

相关推荐
程序员清风14 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林55115 小时前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊21 小时前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing21 小时前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠2 天前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840822 天前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide2 天前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家2 天前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺2 天前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户908324602732 天前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端