一、使用@Insert批量新增
數據庫原始表數據
數據層接口
// 批量新增
@Insert("<script>" +
"INSERT INTO userInfo" +
" (id,name,money)" +
" VALUES" +
" <foreach collection ='list' item='userInfo' separator =','>" +
" (#{userInfo.id}, #{userInfo.name}, #{userInfo.money})" +
" </foreach >" +
"</script>")
void insertUsers(@Param("list") List<userInfo> userInfos);
注意:@Param(“l(fā)ist”) 引號中和foreach 中 collection 屬性值必須寫list,否則報錯。item屬性值寫實體類的類名,首字母必須小寫
接口測試:
由于在Apifox中是沒有對應List的數據類型因此需要我們自己手寫body形式 – json例如:
[
{ "id":4,
"money":"102.3",
"name":"XU"
},
{ "id":5,
"money":"289.64",
"name":"RC"
}
]
除了使用接口測試工具驗證,我們還可以編寫業(yè)務測試類進行測試:
package com.gy;
import com.gy.domain.userInfo;
import com.gy.service.UserService;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import java.util.ArrayList;
import java.util.List;
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest
public class test {
@Autowired
UserService userService;
// 批量新增
@Test
public void test01(){
List<userInfo> userInfos =new ArrayList<>();
userInfos.add(new userInfo(4,"XU",102.3));
userInfos.add(new userInfo(5,"RC",289.64));
userService.insertUsers(userInfos);
}
}
使用以上兩種方式均可進行測試驗證,此時數據均被批量新增成功?。?!
二、使用@Update批量更新
數據庫原始表數據見上圖
數據層接口:
// 批量更新
@Update("<script>" +
" <foreach collection ='list' item='userInfo' separator =';'>" +
"update userInfo set name=#{userInfo.name},money=#{userInfo.money} where id=#{userInfo.id}" +
"</foreach>" +
"</script>")
void updateList(@Param("list") List<userInfo> userInfos);
測試類:
// 批量修改
@Test
public void test04(){
List<userInfo> userInfos =new ArrayList<>();
userInfos.add(new userInfo(3,"NPL",1251.2));
userInfos.add(new userInfo(4,"LL",37.64));
userService.updateList(userInfos);
List<userInfo> infos = userService.getAll();
System.out.println(infos);
}
此處需注意踩坑(本人在此處解決問題時耗費較長時間)
測試運行后出現報錯信息,提示大概為sql語法出現異常,然而多次排查各種(數據庫、字段、表名等等…)問題均無果
發(fā)現sql能夠在navicat上面正常的運行,于是就只有看配置。后來了解到了批量必然要執(zhí)行多行sql。但是mybatis默認是不開啟多行sql執(zhí)行的,于是修改配置,開啟MySQL多行sql執(zhí)行。
url: jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC&allowMultiQueries = true
開啟多行sql執(zhí)行:在數據庫連接信息配置中 url后面加上:`allowMultiQueries = true
可以看到上訴問題立刻得到了解決?文章來源:http://www.zghlxwxcb.cn/news/detail-700241.html
mysql的url參數詳解:文章來源地址http://www.zghlxwxcb.cn/news/detail-700241.html
到了這里,關于SpringBoot中使用@Insert、@Update實現批量新增、更新的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網!