成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

批量刪除的SQL和oracle的寫法

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

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

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

批量刪除很簡(jiǎn)單,大家可能都用過:

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

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

本文重點(diǎn)講述的是批量插入的寫法:

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

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

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

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

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

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

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

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

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

 
 

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-09-02 09:45:07

SQL刪除

2010-09-02 16:46:18

SQL刪除

2010-09-03 11:47:38

SQL刪除

2010-09-01 15:59:44

SQL刪除字段

2010-09-02 10:53:21

SQL刪除

2010-09-01 16:26:11

SQL刪除批量

2010-11-18 09:19:10

Oracle循環(huán)語句

2011-07-11 13:22:28

存儲(chǔ)過程

2010-09-03 11:52:41

SQL刪除

2010-08-04 09:55:34

LINQ to SQL

2010-11-18 13:32:12

Oracle分頁查詢

2010-11-18 17:35:51

oracle時(shí)間加減

2010-09-07 11:41:24

SQL語句

2010-11-02 10:46:14

DB2分頁查詢

2010-09-03 12:01:17

SQL刪除

2010-11-16 10:15:24

oracle創(chuàng)建表空間

2010-09-08 16:38:13

SQL循環(huán)語句

2010-09-25 11:32:20

SQL主鍵約束

2010-10-28 10:37:54

Oracle批量賦權(quán)

2010-11-16 16:26:42

Oracle查詢用戶表
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: av资源中文在线天堂 | 成年视频在线观看 | 天天操一操 | 亚洲视频在线观看 | 亚洲成人国产精品 | 久草日韩 | 精品91久久 | 国产精品永久免费 | 亚洲欧美一区二区三区国产精品 | 欧美久久久久久久 | 欧美日韩亚洲国产综合 | 亚洲人成在线观看 | 日韩欧美亚洲 | 97碰碰碰 | 精品成人一区二区 | 久久亚洲一区二区 | 日韩av免费在线观看 | 一区影视| 国产久 | 亚洲国产精品久久久久 | 红桃视频一区二区三区免费 | 国产一区二区三区在线 | 欧美video | 久久亚洲精品国产精品紫薇 | 一区日韩 | 久久久网| 久久91精品| 欧美一区免费 | 这里精品 | 久久国产欧美日韩精品 | 中文字幕在线观看 | 欧美一级欧美一级在线播放 | 国产高清一区二区三区 | 成人日韩| 欧美激情综合 | 成人动漫一区二区 | 最新国产精品视频 | h在线| 国产精品美女久久久免费 | 国产成人免费视频 | 成年人在线电影 |