MyBatis批量操作、集合遍历-foreach
在使⽤mybatis操作数据库时,经常会使⽤到批量插⼊、IN条件查询的情况,这时就难免要使⽤到foreach元素。下⾯⼀段话摘⾃mybatis官⽹:
foreach 元素的功能是⾮常强⼤的,它允许你指定⼀个集合,声明可以⽤在元素体内的集合项和索引变量。它也允许你指定开闭匹配的字符串以及在迭代中间放置分隔符。这个元素是很智能的,因此它不会偶然地附加多余的分隔符。
图例
接⼝定义
实现
批量插⼊
void batchInsertWorks(@Param("empNo") String empNo, List<Works> worksList);
<insert id="batchInsertWorks" parameterType="java.util.List">
delete from mf_works_schedule where emp_no = #{empNo};
insert into mj_works(id_, emp_no, rest_day, rest_date, update_time)
values
<foreach collection ="worksList" item="item" index= "index" separator =",">
(
#{item.id}, #{pNo}, #{stDay},#{stDate}, now()
)
</foreach >
ON DUPLICATE KEY UPDATE update_time=now();
</insert>
批量更新sql语句
1. 这⾥我传递的参数是List,所有parameterType为java.util.List
2. 在<insert>或其他mybatis的标签中,可以写多个SQL语句,数据库会依次执⾏,记得⼀个语句结束后⽤分号结尾
3. foreach中collection的内容(worksList),就是传递的参数的名字
4. separator表⽰⽤两个对象之间⽤逗号相隔,即:insert into xxx(column1,column2,column3) values(...), (...), (...)
5. item就有点像:for(Works item : worksList) { ... }
6. index在List和数组中,表⽰元素的序号,在map中,index表⽰元素的key
IN查询、删除
List<Order> queryByAppointmentDate(@Param("dateArray") String[] dateArray);
<select id="queryByAppointmentDate" resultMap="Order">
select * from mj_order where appointment_date in
<foreach collection="dateArray" item="item" index="index" open="(" separator="," close=")">
(
#{item}
)
</foreach>
</select>
这⾥的foreach参数和批量插⼊类似,多了个open和close,分表表⽰该语句从什么时候开始,什么时候结束
删除也类似:
void deleteEmpRestInfo(@Param("idArray") String[] idArray);
<delete id="deleteEmpRestInfo">
delete from mj_works where id_ in
<foreach collection="idArray" item="item" index="index" open="(" separator="," close=")">
(
#{item}
)
</foreach>
</delete>
批量更新参数传⼊的是map写法
/**
* @Author: Wu
* @Description: 批量更新
* @Date:
*/
@Test
public void deleteByUpdates(){
Map<String,Object> map =new HashMap<>();
List list=new ArrayList();
list.add(1);
list.add(2);
map.put("status",2);
map.put("list",list);
int a= terminalPrivilegesMapper.updateStatus(map);
System.out.println(a);
<!--批量更新状态-->
<update id="updateStatus" parameterType="java.util.Map">
UPDATE INFO_TERMINALPRIVILEGES SET STATUS = #{status}
WHERE ID IN
<foreach item="item" collection="list" separator="," open="(" close=")">      #{item,jdbcType=DECIMAL}
</foreach>
</update>
批量更新传⼊参数为list写法
<!-- 批量逻辑删除信息 -->
<update id="logicDeletes" parameterType="list">
UPDATE INFO_TERMINALTYPE SET DELETED = 1 WHERE ID IN    <foreach item="item" collection="list" separator="," open="(" close=")">      #{item,jdbcType=DECIMAL}
</foreach>
</update>

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。