1.通用查询结果列
< sql id = " Base_Column_List" > user_id, user_name, user_password
</ sql>
用法:
< select id = " selectUser" resultType = " com.example.YourUser" > SELECT< include refid = " Base_Column_List" /> FROM your_table_name
</ select>
2.动态sql语句更新表
int updateUser ( List < UserPo > userList) ;
< update id = " updateUser" > < foreach collection = " list" separator = " ;" item = " item" index = " index" > update user_table setuser_password=#{item.userPassword}, user_name=#{item.userName}, user_level=#{item.userLevel} where id=#{item.id}</ foreach> </ update>
< update id = " updateUser" > < foreach collection = " list" separator = " ;" item = " item" index = " index" > update user_table< set> < if test = " item.userPassword!=null" > user_password=#{item.userPassword},</ if> < if test = " item.userName!=null" > user_name=#{item.userName},</ if> < if test = " item.userLevel!=null" > user_level=#{item.userLevel},</ if> </ set> where id=#{item.id}</ foreach> </ update>
<update id="updateUser">: 定义了一个 id 为 updateUser 的更新操作。<foreach collection="list" separator=";" item="item" index="index">: 这里使用了 MyBatis 的 <foreach> 标签,它会遍历集合 list 中的元素,并对每个元素执行一次 SQL 操作。separator=";" 表示在每次循环之间用分号分隔,item="item" 和 index="index" 分别定义了在循环过程中当前元素和索引的别名。<set>: 这里表示设置需要更新的字段部分。<if test="item.userPassword!=null">user_password=#{item.userPassword},</if>: 使用 MyBatis 的 <if> 标签来进行条件判断,如果 item 对象中的 userPassword 字段不为 null,则将 user_password 字段赋值为 item.userPassword。where id=#{item.id}: 这部分指定了更新操作的条件,根据 item 对象中的 id 字段的值来确定更新哪条具体记录。
3.动态sql语句新增表
int insertUser ( List < UserPo > userList) ;
< insert id = " insertUser" parameterType = " com.bai.bean.req.UserReq" keyProperty = " id" useGeneratedKeys = " true" > insert into user_table (user_no, user_name, user_level)values< foreach collection = " list" separator = " ," item = " item" > (#{item.userNo},#{item.userName}, #{item.userLevel})</ foreach> </ insert>
<insert id="insertUser" parameterType="com.bai.bean.req.UserReq" keyProperty="id" useGeneratedKeys="true">: 定义了一个 id 为 insertUser 的插入操作,指定了参数类型为 com.bai.bean.req.UserReq,keyProperty="id" 指定了插入后自动生成的主键值要设置到对象的 id 属性上,useGeneratedKeys="true" 表示使用数据库自动生成的主键。insert into user_table ... values ...: 这里是插入语句的开始部分,指定了需要插入的表名和字段列表。<foreach collection="list" separator="," item="item">: 使用 MyBatis 的 <foreach> 标签来遍历集合 list 中的元素,并对每个元素执行一次插入操作。separator="," 表示在每次循环之间用逗号分隔,item="item" 定义了在循环过程中当前元素的别名。(#{item.userNo},#{item.userName}, #{item.userLevel}): 在 values 子句中,根据 item 对象的属性值将数据插入相应的字段中。