mybatis一个方法执行多条sql_MyBatis一次执行多条SQL语句的操作

本文介绍了在MyBatis中如何一次执行多条SQL语句,包括在配置中开启allowMultiQueries,以及通过‘;’分隔SQL,示例涉及删除用户时的关联数据清理。同时讲解了动态SQL中的foreach用法,包括在批量更新和插入中的应用,并展示了不同类型的集合参数处理方式。
摘要由CSDN通过智能技术生成

有个常见的场景:删除用户的时候需要先删除用户的外键关联数据,否则会触发规则报错。

解决办法不外乎有三个:

1、多条sql分批执行;

2、存储过程或函数调用;

3、sql批量执行。

今天我要说的是MyBatis中如何一次执行多条语句(使用mysql数据库)。

1、修改数据库连接参数加上allowMultiQueries=true,如:

hikariConfig.security.jdbcUrl=jdbc:mysql://xx.xx.xx:3306/xxxxx?characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=false&allowMultiQueries=true

2、直接写多条语句,用“;”隔开即可

delete from sec_user_role where userId=#{id};

delete from sec_user where id=#{id};

仅此而已~

补充知识:【MyBatis】动态SQL——foreach使用 /批量更新或批量插入

1.foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合

2.可以传递一个 List 实例或者数组作为参数对象传给 MyBatis。当你这么做的时候,MyBatis 会自动将它包装在一个 Map 中,用名称作为键。List 实例将会以“list”作为键,而数组实例将会以“array”作为键

3.foreach的collection能够支持的三种集合类型list,array以及map

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值