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()),否则数据不会真正进库。

相关推荐
zhangfeng11331 天前
openclaw skills 小龙虾技能 通讯仿真 matlab skill Simulink Agentic Toolkit,通过kimi找到,mcp通讯
开发语言·matlab·openclaw·通讯仿真
Javatutouhouduan1 天前
2026Java面试的正确打开方式!
java·高并发·java面试·java面试题·后端开发·java编程·java八股文
chao1898441 天前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
JAVA面经实录9171 天前
Java初级最终完整版学习路线图
java·spring·eclipse·maven
赏金术士1 天前
Kotlin 习题集 · 高级篇
android·开发语言·kotlin
Cat_Rocky1 天前
k8s-持久化存储,粗浅学习
java·学习·kubernetes
楼兰公子1 天前
buildroot 在编译rust时裁剪平台类型数量的方法
开发语言·后端·rust
知识领航员1 天前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
吴声子夜歌1 天前
Go——并发编程
开发语言·后端·golang
释怀°Believe1 天前
Spring解析
java·后端·spring