日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
批量刪除的SQL和oracle的寫法

批量刪除是數(shù)據(jù)庫使用時經(jīng)常要用到的,本文為您介紹了SQL和oracle批量刪除的寫法,供您參考,希望對您能有所啟迪。

我們這里討論的只是普通sql語句如何寫更高效,不考慮特殊的用文件中轉(zhuǎn)等導(dǎo)入方式,畢竟在代碼中調(diào)用sql語句或存儲過程才更方便。

批量刪除很簡單,大家可能都用過:

DELETE FROM TestTable WHERE ID IN (1, 3, 54, 68)  --sql2005下運行通過

當(dāng)用戶在界面上不連續(xù)的選擇多項進(jìn)行刪除時,該語句比循環(huán)調(diào)用多次刪除或多條delete語句中間加分號一次調(diào)用等方法都高效的多。

本文重點講述的是批量插入的寫法:

sql寫法:

INSERT INTO TestTable SELECT 1, 'abc' UNION SELECT  2, 'bcd'  UNION SELECT 3, 'cde'   --TestTable表沒有主鍵,ID不是主鍵

oracle寫法:

INSERT INTO TestTable SELECT 1, 'abc' From daul UNION SELECT  2, 'bcd' From daul    --TestTable表沒有主鍵,ID不是主鍵

曾經(jīng)測試過,這種寫法插入1000條數(shù)據(jù)比循環(huán)調(diào)用1000次insert或1000條insert語句簡單疊加一次調(diào)用要高效得多,大概快20多倍(調(diào)試狀態(tài)不是太準(zhǔn))。其實很簡單,就用了個union(union all 也可以),但當(dāng)時得出測試結(jié)果時還是很驚喜的。

要得出這個結(jié)果需要兩個條件:

1、表不能有主鍵或者主鍵是數(shù)據(jù)庫默認(rèn)的(sql用自動遞增列,oracle用序列)

2、組合sql語句時只能直接用字符串連接,不能用參數(shù)化sql語句的寫法(就是在組合的sql中用@parm做占位符,再給Command對象添加Parameter)

以上兩條任意一條不滿足,效率的提高都不明顯。

另外,sql語句的最大長度有限制,組合幾千條數(shù)據(jù)寫成一條insert語句,可能會超過上限,所以如果有5000條數(shù)據(jù),可以一次insert 1000條,分5次寫完(不一定一次1000條最合適,有興趣的朋友可以研究)。

聲明:看了幾位朋友的評論后發(fā)現(xiàn)自己沒有敘述清楚

上面的兩個條件并不是說這樣做就好,而是說當(dāng)應(yīng)用場景滿足這兩個條件時才適合用union的寫法

當(dāng)時用這種寫法時,是為了解決一個WinForm程序批量導(dǎo)入手機號碼的問題,程序給自己人用,excel文件也是可靠的,不需要考慮sql攻擊。還有一些場景是大量數(shù)據(jù)來源于通過Gprs網(wǎng)絡(luò)連接的專用終端,總之?dāng)?shù)據(jù)來源是可靠的,還有就是數(shù)據(jù)量很大但不可能巨大。

 


網(wǎng)站題目:批量刪除的SQL和oracle的寫法
文章位置:http://www.5511xx.com/article/cohipjs.html