MyBatis根據(jù)條件批量修改字段的方式
MyBatis根據(jù)條件批量修改字段
背景:
給學生改作業(yè),只要是對的都批量進行數(shù)據(jù)庫的修改
代碼以及注釋
- conttoller
@RestController
@RequestMapping("/work")
public class WorkController {
?? ?@Autowired
?? ?private WorkService workService;
?? ?
?? ?@PutMapping("/examine")
?? ?public HttpResponse examine(Integer[] id) {
?? ??? ?Integer total = workService.examine(id);
?? ??? ?return HttpResponse.ok("共批改[ "+total+" ]條道題","");
?? ?}
}- service
@Service
public class WorkService {
?? ?@Autowired
?? ?private WorkMapper workMapper;
?? ?
?? ?public Integer examine(Integer[] id) {
?? ??? ?return workMapper.examine(id);
?? ?}
}- mapper
@Mapper
public interface WorkMapper {
?? ?Integer examine(@Param("id")Integer[] id);
}- xml
<!--根據(jù)id來批量修改WORK表里面的isEnable字段-->
<update id="examine">
?? ?UPDATE WORK SET isEnable=TRUE WHERE id IN
?? ?<foreach collection="id" item="id" separator="," open="(" close=")">
?? ??? ?#{id}
?? ?</foreach>
</update>- 工具類HttpResponse(此需求中無關緊要的類)
public class HttpResponse {
?? ?private Integer status;
?? ?private String message;
?? ?private Object object;
?? ?
?? ?public static HttpResponse ok(String message) {
?? ??? ?return new HttpResponse(200, message, null);
?? ?}
?? ?
?? ?public static HttpResponse ok(Object object) {
?? ??? ?return new HttpResponse(200, null, object);
?? ?}
?? ?
?? ?public static HttpResponse ok(String message,Object object) {
?? ??? ?return new HttpResponse(200, message, object);
?? ?}
?? ?
?? ?public static HttpResponse error(Integer status, String message) {
?? ??? ?return new HttpResponse(500, message, null);
?? ?}
?? ?
?? ?public static HttpResponse error(String message) {
?? ??? ?return new HttpResponse(500, message, null);
?? ?}
?? ?
?? ?public static HttpResponse error(String message,Object object) {
?? ??? ?return new HttpResponse(500, message, object);
?? ?}
?? ?
?? ?
?? ?protected HttpResponse() {
?? ??? ?super();
?? ?}
?? ?
?? ?private HttpResponse(Integer status, String message, Object object) {
?? ??? ?super();
?? ??? ?this.status = status;
?? ??? ?this.message = message;
?? ??? ?this.object = object;
?? ?}
?? ?public Integer getStatus() {
?? ??? ?return status;
?? ?}
?? ?public void setStatus(Integer status) {
?? ??? ?this.status = status;
?? ?}
?? ?public String getMessage() {
?? ??? ?return message;
?? ?}
?? ?public void setMessage(String message) {
?? ??? ?this.message = message;
?? ?}
?? ?public Object getObject() {
?? ??? ?return object;
?? ?}
?? ?public void setObject(Object object) {
?? ??? ?this.object = object;
?? ?}
}重點:
如果mapper沒加@Param("id")注解會報錯找不到參數(shù)"id"
至此MyBatis根據(jù)id批量修改數(shù)據(jù)庫的某字段需求完成!
MyBatis多條件批量修改
簡單記錄下
想要修改一張表,是聯(lián)合主鍵,也就是where后兩個以上條件才能唯一確定一條數(shù)據(jù)。
如果有唯一鍵,那么foreach中 用in就可以解決。
現(xiàn)在沒辦法用in,不然 A in (#{})and B in (#{})感覺成笛卡爾了。
簡單點就是要實現(xiàn)執(zhí)行多條語句。對update做循環(huán)。傳入?yún)?shù)為 List,ATest類中字段A,B為聯(lián)合主鍵,修改C的值
<update id="update" parameterType="java.util.List">
?? ??? ?<foreach collection="list" ?item="val" separator=";" open="begin" close=";end;">
?? ??? ? ? ?update table_ABC
?? ??? ??? ?<set>
?? ??? ??? ??? ?<if test="val.C!= null">C = #{val.C},</if>
?? ??? ??? ?</set>
?? ??? ??? ?where A=#{val.A} and B= #{val.B}
?? ??? ?</foreach>
?? ?</update>執(zhí)行出來效果為:
begin
update table_ABC set C = '2' where A = '1' and B= '1';
update table_ABC set C = '2' where A = '1' and B= '2';
update table_ABC set C = '4' where A = '3' and B= '2';
end;
這里使用的數(shù)據(jù)庫為oracle,oracle執(zhí)行認為begin和end之前為一條語句
當然,也可以用or 的形式拼接,不過還沒測試。
網(wǎng)上查有的說是mysql數(shù)據(jù)庫 mybatis一次執(zhí)行一條語句。支持多條,可以MySQL連接數(shù)據(jù)庫時,添加語句:“allowMultiQueries=true”
作用:
1.可以在sql語句后攜帶分號,實現(xiàn)多語句執(zhí)行。
2.可以執(zhí)行批處理,同時發(fā)出多個SQL語句。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java實現(xiàn)兩個隨機數(shù)組合并進行排序的方法
本文主要介紹了Java實現(xiàn)兩個隨機數(shù)組合并進行排序的方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
如何使用IDEA開發(fā)Spark SQL程序(一文搞懂)
Spark SQL 是一個用來處理結構化數(shù)據(jù)的spark組件。它提供了一個叫做DataFrames的可編程抽象數(shù)據(jù)模型,并且可被視為一個分布式的SQL查詢引擎。這篇文章主要介紹了如何使用IDEA開發(fā)Spark SQL程序(一文搞懂),需要的朋友可以參考下2021-08-08
SpringBoot之bootstrap和application的區(qū)別解讀
這篇文章主要介紹了SpringBoot之bootstrap和application的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
IDEA中application.properties的圖標顯示不正常的問題及解決方法
這篇文章主要介紹了IDEA中application.properties的圖標顯示不正常的問題及解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04

