91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

平陆县| 尚义县| 文化| 城口县| 城固县| 柳州市| 桑日县| 瑞金市| 宜兴市| 江达县| 娱乐| 柳州市| 凌海市| 米脂县| 象州县| 科技| 奉新县| 铜梁县| 体育| 凉山| 辛集市| 徐汇区| 庄河市| 中宁县| 泰宁县| 石楼县| 东乌| 张掖市| 神池县| 辽阳县| 乌兰县| 永昌县| 裕民县| 平邑县| 公主岭市| 高碑店市| 丘北县| 哈尔滨市| 湟中县| 巢湖市| 靖边县|