這篇文章主要為大家展示了“Mybatis如何使用ExecutorType.BATCH”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Mybatis如何使用ExecutorType.BATCH”這篇文章吧。
八公山網站建設公司創(chuàng)新互聯,八公山網站設計制作,有大型網站制作公司豐富經驗。已為八公山上千家提供企業(yè)網站建設服務。企業(yè)網站搭建\成都外貿網站建設要多少錢,請找那個售后服務好的八公山做網站的公司定做!
使用ExecutorType.BATCH
Mybatis內置的ExecutorType有3種,默認為simple,該模式下它為每個語句的執(zhí)行創(chuàng)建一個新的預處理語句,單條提交sql;而batch模式重復使用已經預處理的語句,并且批量執(zhí)行所有更新語句,顯然batch性能將更優(yōu); 但batch模式也有自己的問題,比如在Insert操作時,在事務沒有提交之前,是沒有辦法獲取到自增的id,這在某型情形下是不符合業(yè)務要求的
具體用法如下
//批量保存方法測試 @Test public void testBatch() throws IOException{ SqlSessionFactory sqlSessionFactory = getSqlSessionFactory(); //可以執(zhí)行批量操作的sqlSession SqlSession openSession = sqlSessionFactory.openSession(ExecutorType.BATCH); //批量保存執(zhí)行前時間 long start = System.currentTimeMillis(); try { EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class); for (int i = 0; i < 1000; i++) { mapper.addEmp(new Employee(UUID.randomUUID().toString().substring(0, 5), "b", "1")); } openSession.commit(); long end = System.currentTimeMillis(); //批量保存執(zhí)行后的時間 System.out.println("執(zhí)行時長" + (end - start)); //批量 預編譯sql一次==》設置參數==》10000次==》執(zhí)行1次 677 //非批量 (預編譯=設置參數=執(zhí)行 )==》10000次 1121 } finally { openSession.close(); } }
mapper和mapper.xml如下
public interface EmployeeMapper { //批量保存員工 Long addEmp(Employee employee); }
<mapper namespace="com.jourwon.mapper.EmployeeMapper" <!--批量保存員工 --> <insert id="addEmp"> insert into employee(lastName,email,gender) values(#{lastName},#{email},#{gender}) </insert> </mapper>
以上是“Mybatis如何使用ExecutorType.BATCH”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道!
分享名稱:Mybatis如何使用ExecutorType.BATCH
文章出自:http://www.rwnh.cn/article22/ihjpjc.html
成都網站建設公司_創(chuàng)新互聯,為您提供商城網站、域名注冊、企業(yè)網站制作、ChatGPT、網站設計公司、品牌網站設計
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯