JSP 多條SQL語句同時執行的方法

來源:互聯網
上載者:User

複製代碼 代碼如下:con.setAutoCommit(true);//設為true,每次executeUpdate將立刻被執行
sql = "insert into table1(lable1) values('001')";
rs = stmt.executeUpdate(sql);
sql = "insert into table2(lable2) values('002')";
rs = stmt.executeUpdate(sql);

這是一段基本的SQL插入語句,分別將兩個值插入到兩個表中,上面的程式已經能夠完成這一需求,但是實際操作中並不建議這樣寫,原因如下:
1、程式順序執行,假如第一條語句入庫了,後面一條發生了不可預知的錯誤而入庫失敗,
這樣的情況是不被允許的,如果其中一條出錯,就應該全部都不予執行。
2、這裡是連續插入2條資料,感覺連續提交兩次很正常,但是假如我們擴大這個問題,連續插入1000
條資料,每次都自動的COMMIT了,這對伺服器效能來說是一種浪費。
因此我們遇到多條SQL語句需要同時執行,就應該把程式改為:
con.setAutoCommit(false);//設為false,每次executeUpdate將不會立刻提交,而是等待commit();
sql = "insert into table1(lable1) values('001')";
rs = stmt.executeUpdate(sql);
sql = "insert into table2(lable2) values('002')";
rs = stmt.executeUpdate(sql);
con.commit();
首先把setAuoCommit()設為false,不自動執行。然後正常入庫,當所有需要入庫的語句都預執行了,然後在進行 commit();這跟前面的代碼有什麼不一樣的地方呢?
1、假如兩條語句中任意一條出問題,兩條語句都不會被執行,但是同樣可以用catch來擷取出錯提示
2、對於需要同時提交1000條記錄,我們可以每100條,進行一次commit();這樣只需要執行10次提交運行速度會有明顯的提升。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.