SQL Server 2008 收縮日誌

來源:互聯網
上載者:User

標籤:收縮日誌

SQL SERVER 2008 中 BACKUP LOG WITH TRUNCATE_ONLY 已不再被支援,要收縮資料庫日誌,首先需要通過將資料庫復原模式設定為 SIMPLE 來截斷該檔案。

語句如下:

USE DATABASENAME;

GO
-- Truncate the log by changing the database recovery model to SIMPLE.

ALTER DATABASE DATABASENAME SET RECOVERY SIMPLE;

GO
-- Shrink the truncated log file to 1 MB.

DBCC SHRINKFILE (DATABASENAME_Log, 1);

GO
-- Reset the database recovery model.

ALTER DATABASE DATABASENAME SET RECOVERY FULL;

GO
也可以通過圖形介面來完成。

通過先備份日誌,然後再收縮記錄檔,如下:

back database mydb to disk=‘mydb_bak‘;

dbcc shinkfile(mydb_log,10);--收縮至10m

報錯:
[Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 資料庫 ‘riskDB‘ 的交易記錄已滿。若要查明無法重用日誌中的空間的原因,
請參閱 sys.databases 中的 log_reuse_wait_desc 列。]

select name,log_reuse_wait_desc from sys.databases
----發現結果中對應到這個資料庫的log_reuse_wait_desc為REPLICATION表示記錄檔不能被壓縮是因為replication
alter database riskDB set recovery simple
use riskDB
dbcc shrinkfile(‘riskDB_log‘,10)
alter database riskDB set recovery full
----

SQL Server 2008 收縮日誌

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.