SQL Server清空日誌及所有表的資料

來源:互聯網
上載者:User
在查詢分析器中順序執行以下三步,其中   databasename   為你的資料庫檔案名
1.清空日誌:DUMP   TRANSACTION   databasename   WITH   NO_LOG  

2.截斷交易記錄:BACKUP   LOG   databasename   WITH   NO_LOG  

3.收縮資料庫:DBCC   SHRINKDATABASE(databasename)  

--//////////////////////////////////////////////////////////////////

SQL   Server日誌清空方法  
   
一種方法:清空日誌。  
1.開啟查詢分析器,輸入命令   DUMP   TRANSACTION   資料庫名   WITH   NO_LOG  
2.再開啟企業管理器--右鍵你要壓縮的資料庫--所有任務--收縮資料庫--收縮檔案--選擇記錄檔--在收縮方式裡選擇收縮至XXM,這裡會給出一個允許收縮到的最小M數,直接輸入這個數,確定就可以了。

方法二:

清空日誌:

------------------------------------------
  BACKUP   LOG     庫名   WITH   NO_LOG

  DBCC   SHRINKFILE(   '記錄檔名 ',新的大小數值型如1)

記錄檔名是這樣的:

select   name   from   sysfiles
如:
mastlog

---------------------------------------------
backup   log     DATABASENAME
  with   truncate_only
  dbcc   shrinkdatabase   (DATABASENAME,SIZE)  
  若每天有whole   back   up   的話可以設定一job,
  每隔三天或一個星期清空一次
  這樣的話日誌就不會長大了哦

-------------------------------------
1:   刪除LOG
1:分離資料庫
2:刪除LOG檔案
3:附加資料庫
此法產生新的LOG,大小隻有500多K
      再將此資料庫設定自動收縮
2:清空日誌
DUMP     TRANSACTION     庫名     WITH     NO_LOG        

再:
企業管理器--右鍵你要壓縮的資料庫--所有任務--收縮資料庫--收縮檔案--選擇記錄檔--在收縮方式裡選擇收縮至XXM,這裡會給出一個允許收縮到的最小M數,直接輸入這個數,確定就可以了

方法三:  
第一步:  
backup   log   database_name   with   no_log  
或者   backup   log   database_name   with   truncate_only   --no_log和truncate_only是在這裡是同義的,隨便執行哪一句都可以  
第二步:  
1.收縮特定資料庫的所有資料和記錄檔,執行   dbcc   shrinkdatabase   (database_name,[,target_percent])--database_name是要收縮的資料庫名稱;target_percent是資料庫收縮後的資料庫檔案中所要的剩餘可用空間百分比  
2.收縮一次一個特定資料庫中的資料或記錄檔,執行   dbcc   shrinkfile(file_id,[,target_size])   --file_id是要收縮的檔案的標識   (ID)   號,若要獲得檔案   ID,請使用   FILE_ID   函數或在當前資料庫中搜尋   sysfiles;target_size是用MB表示的所要的檔案大小(用整數表示)。如果沒有指定,dbcc   shrinkfile   將檔案大小減少到預設檔案大小  

兩個dbcc都可以帶上參數notruncate或truncateonly,具體意思看協助。  

方法四:  
(這個方法在sqlserver2000的環境下做一般能成功,在sqlserver7及以下版本就不一定了):  
第一步:  
先備份整個資料庫以備不測  
第二步:  
備份結束後,在Query   Analyzer中執行如下的語句:  
exec   sp_detach_db   yourDBName,true   --卸載這個DB在MSSQL中的註冊資訊  
第三步:  
到日誌的物理檔案所在的目錄中去刪除該記錄檔或者將該記錄檔移出該目錄  
第四步:  
在Query   Analyzer中執行如下的語句:  
exec   sp_attach_single_file_db   yourDBName, 'd:/mssql7/data/yourDBName_data.mdf '  
--以單檔案的方式註冊該DB,如果成功則MSSQL將自動為這個DB產生一個500K的記錄檔。  

以上方法在清除log日誌中均有效。  
但,能否讓sql   server   不產生log日誌呢?以上方法好像均無效。  
我這兒正好有個case:  
我客戶的sql   server每天都會產生4,500M的log日誌,每天都清除一下,非常不便。有沒有辦法實現不產生log日誌呢?  

我分析了一下客戶產生log日誌的原因,並且做了相應測試。  
客戶是每天將資料庫清空,從總系統中將資料匯入到sql   server裡。我感決sqlserver在插入時產生log不大,在delete整個庫時產生log極大。  
比如:  
SELECT   *   into   test_2   from   b_bgxx  
共45000條記錄,產生十幾M   log,如果  
delete   from   test_2  
產生80多M   log   ,這明顯存在問題。  

雖然可以換成:  
truncate   table   test_2  

 

近來探索資料庫過大,空間不足,因此打算將資料庫的資料進行全面的清理,但表非常多,一張一張的清空,實在麻煩,因此就想利用SQL語句一次清空所有資料.找到了三種方法進行清空.使用的資料庫為MS SQL SERVER.
1.搜尋出所有表名,構造為一條SQL語句

declare @trun_name varchar(8000)
set @trun_name=''
select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='U' and status > 0
exec (@trun_name)

該方法適合表不是非常多的情況,否則表數量過多,超過字串的長度,不能進行完全清理.
2.利用遊標清理所有表

declare @trun_name varchar(50)
declare name_cursor cursor for
select 'truncate table ' + name from sysobjects where xtype='U' and status > 0
open name_cursor
fetch next from name_cursor into @trun_name
while @@FETCH_STATUS = 0
begin
  exec (@trun_name)
 print 'truncated table ' + @trun_name
 fetch next from name_cursor into @trun_name
end
close name_cursor
deallocate name_cursor

這是我自己構造的,可以做為預存程序調用, 能夠一次清空所有表的資料,並且還可以進行有選擇的清空表.
3.利用微軟未公開的預存程序

exec sp_msforeachtable "truncate table ?"

 

該方法可以一次清空所有表,但不能加過濾條件.

 

近來探索資料庫過大,空間不足,因此打算將資料庫的資料進行全面的清理,但表非常多,一張一張的清空,實在麻煩,因此就想利用SQL語句一次清空所有資料.找到了三種方法進行清空.使用的資料庫為MS SQL SERVER.
1.搜尋出所有表名,構造為一條SQL語句

declare @trun_name varchar(8000)
set @trun_name=''
select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='U' and status > 0
exec (@trun_name)

該方法適合表不是非常多的情況,否則表數量過多,超過字串的長度,不能進行完全清理.
2.利用遊標清理所有表

declare @trun_name varchar(50)
declare name_cursor cursor for
select 'truncate table ' + name from sysobjects where xtype='U' and status > 0
open name_cursor
fetch next from name_cursor into @trun_name
while @@FETCH_STATUS = 0
begin
  exec (@trun_name)
 print 'truncated table ' + @trun_name
 fetch next from name_cursor into @trun_name
end
close name_cursor
deallocate name_cursor

這是我自己構造的,可以做為預存程序調用, 能夠一次清空所有表的資料,並且還可以進行有選擇的清空表.
3.利用微軟未公開的預存程序

exec sp_msforeachtable "truncate table ?"

 

該方法可以一次清空所有表,但不能加過濾條件.

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.