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