欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

最簡單刪除SQL Server中所有數據的方法

系統 2569 0
原文: 最簡單刪除SQL Server中所有數據的方法

? 最簡單刪除SQL Server 中所有數據的方法

?

編寫人: CC 阿爸

?

2014-3-14

其實刪除數據庫中數據的方法并不復雜,為什么我還要多此一舉呢,一是我這里介紹的是刪除數據庫的所有數據,因為數據之間可能形成相互約束關系,刪除操作可能陷入死循環,二是這里使用了微軟未正式公開的 sp_MSForEachTable 存儲過程。

也許很多讀者朋友都經歷過這樣的事情:要在開發數據庫基礎上清理一個空庫,但由于對數據庫結構缺乏整體了解,在刪除一個表的記錄時,刪除不了,因為可能有外鍵約束,一個常見的數據庫結構是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說道刪除數據記錄,往往馬上會想到的是 delete truncate 語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命的是這兩個命令都只能一次操作一個表。那么真正遇到要刪除 SQL Server 數據庫中所有記錄時,該怎么辦呢?有兩個選擇:

1. 按照先后順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關系,然后找出先刪哪個表,再刪哪個表,最后又刪哪個表。

2. 禁用所有約束,刪除所有數據,最后再啟用約束,這樣就不用花時間和精力去研究什么約束了,只需要編寫一個簡單的存儲過程就可以自動完成這個任務。
從這兩個選擇中不難看出第二個選擇是最簡單有效的了,那么在使用第二個選擇時,具體該怎么實施呢?

首先得編寫代碼循環檢查所有的表,這里我推薦一個存儲過程 sp_MSForEachTable ,因為在微軟的官方文檔中沒有對這個存儲過程有描述,很多開發人員也許都還未曾聽說,所以你在互聯網上搜索得到的解決辦法大多很復雜,也許有的人會認為,既然沒有官方文檔,這個存儲過程可能會不穩定,打心理上會排斥它,但事實并非如此。下面來先看一個完整的腳本:

CREATE PROCEDURE sp_DeleteAllData
AS
EXEC sp_MSforeachtable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
EXEC sp_MSforeachtable 'ALTER TABLE ? DISABLE TRIGGER ALL'
EXEC sp_MSforeachtable 'DELETE FROM ?'
EXEC sp_MSforeachtable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
EXEC sp_MSforeachtable ALTER TABLE ? ENABLE TRIGGER ALL'
EXEC sp_MSforeachtable 'SELECT * FROM ?'
GO

大小寫要區分開來。

這個腳本創建了一個命名為 sp_DeleteAllData 的存儲過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有數據,接下里的語句分別還原約束和觸發器,最后一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。

你可以在任何數據庫上運行這個存儲過程,當然不要在生成數據庫上運行,可別怪我沒告訴你!不管怎樣,還是先備份一下數據庫,使用備份數據庫還原,然后再運行該存儲過程,呵呵,即使是一個大型數據庫,也要不多長時間,你的數據庫就成一個空庫了,有點怕怕的感覺!

?

根據以上,我們又引出了 sp_MSforeachtable sp_MSforeachdb 這兩個 sp 的由來

MSSQL 里有許多不公開的系統存儲過程,其中可能常用的 sp_MSforeachtable sp_MSforeachdb 有這 2 個。
分別用于遍歷某數據庫的每個用戶表、每個數據庫。

最簡單刪除SQL Server中所有數據的方法


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 91成人午夜性a一级毛片 | 亚洲综合色视频在线观看 | 一区二区播放 | 国产在线一区二区三区 | 激情啪啪网站 | 91偷拍精品一区二区三区 | 亚洲va欧美va天堂v国产综合 | 国产高清永久免费 | 香蕉国产人午夜视频在线观看 | www国产成人免费观看视频,深夜成人网 | 欧美一级在线播放 | 亚洲依依成人综合网站 | 欧美一区二区三区在观看 | www.亚洲在线 | av中文字幕在线观看 | 国产美女精品 | 91福利免费体验区观看区 | free-porn-ok| 精彩视频一区 | 69久久夜色精品国产69 | 欧美久久综合性欧美 | 亚州中文字幕 | 欧美a在线看 | 日本高清无卡码一区二区久久 | 国产日韩一区 | 久草免费小视频 | 国产牛仔裤系列在线观看 | 亚洲欧美精品一区二区 | 亚洲欧美日韩高清一区二区三区 | 999精品视频| 欧美一级一毛片 | 人妻体内射精一区二区三四 | 欧美激情视频一区二区三区在线播放 | 日韩不卡高清 | 久久99精品久久 | 一级a级国产不卡毛片 | 国产色拍拍视频在线 | 久色 | 成人嘿嘿视频网站在线 | 日韩精品一区二区三区在线播放 | 国产目拍亚洲精品区一区 |