Mybatis的<insert>,<update>,<delete>标签用法

之前对mybatis的<select>标签以及其他相关标签做了讲解,很多标签也是可以拿到增删改的标签中来用的,下面先说下<insert>标签的用法:

<insert>标签顾名思义就是插入语句,用于将数据插入到数据库中,一般插入标签没有返回值,传入一个实体对象的数据,一般不对插入的数据做判断,因为是新的一笔数据,即使是null值也可以插入,一些业务逻辑的判断应该放在前端实现。下面写一个例子:

<insert id="insertUser" parameterType="User">
  INSERT INTO sys_user (name, age, email)
  VALUES (#{name}, #{age}, #{email})
</insert>

但是有时候存在子表数据一起插入的情况,而此时数据库的id又是自增长,那么就需要返回插入数据的id,用来作为从表的外键插入到数据库,需要引入一个新的标签<selectKey>专门用来查询插入后返回的id。那么插入语句就可以改成这个样子:

<insert id="insertUser" parameterType="User">
  <selectKey keyProperty="id" resultType="int" order="AFTER">
    SELECT LAST_INSERT_ID()
  </selectKey>
  INSERT INTO sys_user (name, age, email)
  VALUES (#{name}, #{age}, #{email})
</insert>

还有一种实现方式是通过给insert标签添加属性来实现:

<insert id="insertUser" usegeneratedKeys="true" keyProperty="id" parameterType="User">
  INSERT INTO sys_user (name, age, email)
  VALUES (#{name}, #{age}, #{email})
</insert>

<update>的实现方式也是如此,只不过update正常都是通过id修改,不会需要返回id,不过<update>标签需要注意的是有时候会希望返回影响的行数,那么同样可以用<selectKey>标签,具体代码如下:

<update id="updateUser" parameterType="User" statementType="PREPARED">
  <selectKey keyProperty="rowCount" resultType="int" order="AFTER">
    SELECT ROW_COUNT()
  </selectKey>
  UPDATE sys_user
  SET name = #{name}, age = #{age}, email = #{email}
  WHERE id = #{id}
</update>

同时,<update>还经常存在一种需求是如果传入的值为null则不修改数据库原有的值,如果传入的数据是有效值,则修改原有的值,那么这里就要结合<if>标签做一些判断了。这里要引入一个标签<set>,例子如下:

<update id="updateUser" parameterType="User">
  UPDATE sys_user
  <set>
    <if test="name != null">
      name = #{name},
    </if>
    <if test="age != null">
      age = #{age},
    </if>
    <if test="email != null">
      email = #{email},
    </if>
  </set>
  WHERE id = #{id}
</update>

不希望更新传入数据为null的值,也就是传入的字段有值则修改,如果没有值则不修改,不过要注意的是起码要保证有一个条件是存在的,否则sql会成为以下这样:update sys_user where id = #{id},这样sql是报错的。

<delete> 最后再说下<delete>标签,这个标签也是最简单的,只需要判断条件是否满足然后删除掉对应的数据就好了,例子:

<delete id="deleteUser" parameterType="int">
  DELETE FROM 
  WHERE id = #{userId}
</delete>

也可以判断条件的是否存在,但是一般删除操作比较谨慎,不会多条件筛选删除。否则会出现误删的清理,判断条件的方式与查询里的方式一致,可以参考查询里的实现方式。

好了,已上如有问题可以在评论区给我留言

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

baker_zhuang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值