JSP 多條SQL語句同時(shí)執(zhí)行的方法
更新時(shí)間:2009年02月18日 22:46:01 作者:
這是一段基本的SQL插入語句,分別將兩個(gè)值插入到兩個(gè)表中,上面的程序已經(jīng)能夠完成這一需求,但是實(shí)際操作中并不建議這樣寫
復(fù)制代碼 代碼如下:
con.setAutoCommit(true);//設(shè)為true,每次executeUpdate將立刻被執(zhí)行
sql = "insert into table1(lable1) values('001')";
rs = stmt.executeUpdate(sql);
sql = "insert into table2(lable2) values('002')";
rs = stmt.executeUpdate(sql);
這是一段基本的SQL插入語句,分別將兩個(gè)值插入到兩個(gè)表中,上面的程序已經(jīng)能夠完成這一需求,但是實(shí)際操作中并不建議這樣寫,原因如下:
1、程序順序執(zhí)行,假如第一條語句入庫了,后面一條發(fā)生了不可預(yù)知的錯(cuò)誤而入庫失敗,
這樣的情況是不被允許的,如果其中一條出錯(cuò),就應(yīng)該全部都不予執(zhí)行。
2、這里是連續(xù)插入2條數(shù)據(jù),感覺連續(xù)提交兩次很正常,但是假如我們擴(kuò)大這個(gè)問題,連續(xù)插入1000
條數(shù)據(jù),每次都自動(dòng)的COMMIT了,這對(duì)服務(wù)器性能來說是一種浪費(fèi)。
因此我們遇到多條SQL語句需要同時(shí)執(zhí)行,就應(yīng)該把程序改為:
con.setAutoCommit(false);//設(shè)為false,每次executeUpdate將不會(huì)立刻提交,而是等待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()設(shè)為false,不自動(dòng)執(zhí)行。然后正常入庫,當(dāng)所有需要入庫的語句都預(yù)執(zhí)行了,然后在進(jìn)行 commit();這跟前面的代碼有什么不一樣的地方呢?
1、假如兩條語句中任意一條出問題,兩條語句都不會(huì)被執(zhí)行,但是同樣可以用catch來獲取出錯(cuò)提示
2、對(duì)于需要同時(shí)提交1000條記錄,我們可以每100條,進(jìn)行一次commit();這樣只需要執(zhí)行10次提交運(yùn)行速度會(huì)有明顯的提升。
相關(guān)文章
jsp中如何實(shí)現(xiàn)按下回車鍵自動(dòng)提交表單
當(dāng)提交form表單數(shù)據(jù)時(shí)直接觸發(fā)回車鍵,就可以提交表單。為了省事很多時(shí)候希望可以按回車鍵來提交表單,要控制這些行為,可以借助JS來達(dá)到要求。2016-10-10
JSP自定義標(biāo)簽rtexprvalue屬性用法實(shí)例分析
這篇文章主要介紹了JSP自定義標(biāo)簽rtexprvalue屬性用法,以實(shí)例形式較為詳細(xì)的分析了自定義標(biāo)簽rtexprvalue屬性相關(guān)使用技巧與注意事項(xiàng),具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10
JavaServlet的文件上傳和下載實(shí)現(xiàn)方法
下面小編就為大家分享一篇JavaServlet的文件上傳和下載實(shí)現(xiàn)方法具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02
JavaScript結(jié)合PHP實(shí)現(xiàn)網(wǎng)頁制作中雙下拉菜單的動(dòng)態(tài)實(shí)現(xiàn)
在網(wǎng)頁制作中,常常遇到這種情況,通過主下拉菜單的選擇,動(dòng)態(tài)的生成子下拉菜單。本文介紹了雙下拉菜單的動(dòng)態(tài)實(shí)現(xiàn),有需要的可以來了解一下。2016-10-10

