中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis如何使用ExecutorType.BATCH

發布時間:2022-03-25 10:51:31 來源:億速云 閱讀:2442 作者:小新 欄目:web開發

這篇文章主要為大家展示了“Mybatis如何使用ExecutorType.BATCH”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Mybatis如何使用ExecutorType.BATCH”這篇文章吧。

使用ExecutorType.BATCH

Mybatis內置的ExecutorType有3種,默認為simple,該模式下它為每個語句的執行創建一個新的預處理語句,單條提交sql;而batch模式重復使用已經預處理的語句,并且批量執行所有更新語句,顯然batch性能將更優; 但batch模式也有自己的問題,比如在Insert操作時,在事務沒有提交之前,是沒有辦法獲取到自增的id,這在某型情形下是不符合業務要求的

具體用法如下

//批量保存方法測試
@Test  
public void testBatch() throws IOException{
    SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
    //可以執行批量操作的sqlSession
    SqlSession openSession = sqlSessionFactory.openSession(ExecutorType.BATCH);

    //批量保存執行前時間
    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();
        //批量保存執行后的時間
        System.out.println("執行時長" + (end - start));
        //批量 預編譯sql一次==》設置參數==》10000次==》執行1次   677
        //非批量  (預編譯=設置參數=執行 )==》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”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥江县| 盐池县| 柏乡县| 惠州市| 介休市| 建湖县| 镇赉县| 仁怀市| 麻城市| 濮阳市| 郑州市| 敦化市| 建湖县| 林芝县| 泰州市| 墨竹工卡县| 宜昌市| 翼城县| 武城县| 阜新| 含山县| 隆化县| 墨竹工卡县| 嘉荫县| 遂宁市| 拜城县| 于都县| 许昌市| 莱阳市| 安义县| 青田县| 昆山市| 瑞安市| 井陉县| 志丹县| 旬邑县| 云阳县| 会昌县| 讷河市| 璧山县| 金坛市|