java之mybatis语法

1、增加(Insert):

bash 复制代码
xml
<insert id="insertUser" parameterType="User">
  INSERT INTO user (id, name, age) VALUES (#{id}, #{name}, #{age})
</insert>
对应Java代码:

java
sqlSession.insert("insertUser", user);
sqlSession.commit();

2、删除(Delete):

bash 复制代码
xml
<delete id="deleteUserById" parameterType="int">
  DELETE FROM user WHERE id = #{id}
</delete>
对应Java代码:

java
sqlSession.delete("deleteUserById", userId);
sqlSession.commit();

3、修改(Update):

bash 复制代码
xml
<update id="updateUser" parameterType="User">
  UPDATE user SET name = #{name}, age = #{age} WHERE id = #{id}
</update>
对应Java代码:

java
sqlSession.update("updateUser", user);
sqlSession.commit();

4、查询(Select):

bash 复制代码
xml
<select id="getUserById" parameterType="int" resultType="User">
  SELECT * FROM user WHERE id = #{id}
</select>
对应Java代码:

java
User user = sqlSession.selectOne("getUserById", userId);

在MyBatis中,可以使用动态SQL来构建灵活的增删改查语句,以应对不同的查询条件和业务需求。以下是一些常见的动态SQL语法示例:

5、动态条件查询:

bash 复制代码
xml
<select id="getUserByCondition" parameterType="Map" resultType="User">
  SELECT * FROM user
  <where>
    <if test="name != null">
      AND name = #{name}
    </if>
    <if test="age != null">
      AND age = #{age}
    </if>
  </where>
</select>
对应Java代码:

java
Map<String, Object> params = new HashMap<>();
params.put("name", "John");
List<User> users = sqlSession.selectList("getUserByCondition", params);

6、动态插入:

bash 复制代码
xml
<insert id="insertUser" parameterType="User">
  INSERT INTO user
  <trim prefix="(" suffix=")" suffixOverrides=",">
    <if test="name != null">name,</if>
    <if test="age != null">age,</if>
  </trim>
  <trim prefix="values (" suffix=")" suffixOverrides=",">
    <if test="name != null">#{name},</if>
    <if test="age != null">#{age},</if>
  </trim>
</insert>
对应Java代码:

java
User user = new User("Alice", 25);
sqlSession.insert("insertUser", user);
sqlSession.commit();

7、 动态更新:

bash 复制代码
xml
<update id="updateUser" parameterType="User">
  UPDATE user
  <set>
    <if test="name != null">name = #{name},</if>
    <if test="age != null">age = #{age},</if>
  </set>
  WHERE id = #{id}
</update>
对应Java代码:

java
User user = new User(1, "Bob", 30);
sqlSession.update("updateUser", user);
sqlSession.commit();

8、动态删除:

bash 复制代码
xml
<delete id="deleteUserByCondition" parameterType="Map">
  DELETE FROM user
  <where>
    <if test="name != null">AND name = #{name}</if>
    <if test="age != null">AND age = #{age}</if>
  </where>
</delete>
对应Java代码:

java
Map<String, Object> params = new HashMap<>();
params.put("name", "Tom");
sqlSession.delete("deleteUserByCondition", params);
sqlSession.commit();
相关推荐
清霜之辰10 分钟前
详解 kotlin 相对 Java 特有的关键字及使用
android·java·kotlin
江沉晚呤时12 分钟前
深入解析策略模式在C#中的应用与实现
java·服务器·开发语言·前端·.netcore
居然是阿宋13 分钟前
Kotlin 中的 `reified` 关键字全解析:保留类型信息 + 优化高阶函数的双重魔法
android·开发语言·kotlin
Hamm14 分钟前
如何在TypeScript里使用类封装枚举来实现Java的枚举形参倒置
java·前端·typescript
mikey棒棒棒32 分钟前
使用RabbitMQ实现异步秒杀
java·分布式·rabbitmq·mq
无情的搬砖机器32 分钟前
idea 打不开terminal
java·ide·intellij-idea
avi911134 分钟前
问问lua怎么写DeepSeek,,,,,
java·junit·lua·deepseek
安迪小宝1 小时前
python基础语法13-装饰器
开发语言·前端·python
小八四爱吃甜食1 小时前
【R语言绘图】圈图绘制代码
开发语言·r语言
残月只会敲键盘1 小时前
C++ Lambda表达式简明指南:新手快速上手
开发语言·c++