国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JSP > 正文

JSP 多條SQL語句同時執(zhí)行的方法

2020-07-27 21:42:03
字體:
供稿:網(wǎng)友
復制代碼 代碼如下:

con.setAutoCommit(true);//設為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插入語句,分別將兩個值插入到兩個表中,上面的程序已經(jīng)能夠完成這一需求,但是實際操作中并不建議這樣寫,原因如下:
1、程序順序執(zhí)行,假如第一條語句入庫了,后面一條發(fā)生了不可預知的錯誤而入庫失敗,
這樣的情況是不被允許的,如果其中一條出錯,就應該全部都不予執(zhí)行。
2、這里是連續(xù)插入2條數(shù)據(jù),感覺連續(xù)提交兩次很正常,但是假如我們擴大這個問題,連續(xù)插入1000
條數(shù)據(jù),每次都自動的COMMIT了,這對服務器性能來說是一種浪費。
因此我們遇到多條SQL語句需要同時執(zhí)行,就應該把程序改為:
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,不自動執(zhí)行。然后正常入庫,當所有需要入庫的語句都預執(zhí)行了,然后在進行 commit();這跟前面的代碼有什么不一樣的地方呢?
1、假如兩條語句中任意一條出問題,兩條語句都不會被執(zhí)行,但是同樣可以用catch來獲取出錯提示
2、對于需要同時提交1000條記錄,我們可以每100條,進行一次commit();這樣只需要執(zhí)行10次提交運行速度會有明顯的提升。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 尼玛县| 山阳县| 古交市| 宿松县| 平乡县| 漾濞| 孝昌县| 郓城县| 洪湖市| 滕州市| 赤壁市| 玉山县| 白城市| 土默特左旗| 渝北区| 丰台区| 江陵县| 霍州市| 萍乡市| 托里县| 玉门市| 罗源县| 龙川县| 四平市| 涿鹿县| 江津市| 北流市| 阳山县| 娄底市| 晋城| 南昌市| 南丹县| 丰顺县| 九寨沟县| 温泉县| 马山县| 林芝县| 六盘水市| 兰州市| 奈曼旗| 连州市|