MSSQL 2005/2008 日志壓縮清理方法小結
更新時間:2013年03月28日 17:04:52 作者:
本教程會詳細介紹下MSSQL 2005和MSSQL 2008刪除或壓縮數據庫日志的方法,感興趣的朋友可以參考下哈,希望可以幫助到你
適用于SQL Server 2005的方法
---------------------------------------------
USE DNName
GO
1,清理日志
Backup Log DNName WITH no_log
GO
2,截斷事務日志
DUMP TRANSACTION DNName WITH no_log
GO
3,收縮
兩種方式:
1):壓縮數據庫
DBCC SHRINKDATABASE(庫名)
GO
2):指定數據文件,可以通過這個語句查詢到:select * from sysfiles
此方式也可以通過操作:右鍵你要壓縮的數據庫--所有任務--收縮數據庫--收縮文件,分別選擇數據和日志的文件要壓縮的大小來執(zhí)行
DBCC SHRINKFILE (文件名)
GO
4.為了最大化的縮小日志文件(如果是sql 7.0,這步只能在查詢分析器中進行)
下面的示例分離 pubs,然后將 pubs 中的一個文件附加到當前服務器。
a.分離
EXEC sp_detach_db @dbname='庫名'
b.刪除日志LOG文件
c.再附加
EXEC sp_attach_single_file_db @dbname='庫名',
@physname='c:\Program Files\Microsoft SQL Server\MSSQL\Data\庫名.mdf'
5.為了以后能自動收縮,做如下設置:
企業(yè)管理器--服務器--右鍵數據庫--屬性--選項--選擇"自動收縮"
--SQL語句設置方式:
EXEC sp_dboption '庫名', 'autoshrink', 'TRUE'
6.如果想以后不讓它日志增長得太大
企業(yè)管理器--服務器--右鍵數據庫--屬性--事務日志
--將文件增長限制為xM(x是你允許的最大數據文件大小)
--SQL語句的設置方式:
alterdatabase 庫名 modify file(name=邏輯文件名,maxsize=20)
------分--隔-----
適用于SQL Server 2008的方法
[code]
USE [master]
GO
ALTER DATABASE DNName SET RECOVERY SIMPLE WITH NO_WAIT
GO
ALTER DATABASE DNName SET RECOVERY SIMPLE --簡單模式
GO
USE DNName
GO
DBCC SHRINKFILE (N'DNName_Log' , 11, TRUNCATEONLY)
GO
USE [master]
GO
ALTER DATABASE DNName SET RECOVERY FULL WITH NO_WAIT
GO
ALTER DATABASE DNName SET RECOVERY FULL --還原為完全模式
GO
[code]
---------------------------------------------
復制代碼 代碼如下:
USE DNName
GO
1,清理日志
復制代碼 代碼如下:
Backup Log DNName WITH no_log
GO
2,截斷事務日志
復制代碼 代碼如下:
DUMP TRANSACTION DNName WITH no_log
GO
3,收縮
兩種方式:
1):壓縮數據庫
DBCC SHRINKDATABASE(庫名)
GO
2):指定數據文件,可以通過這個語句查詢到:select * from sysfiles
此方式也可以通過操作:右鍵你要壓縮的數據庫--所有任務--收縮數據庫--收縮文件,分別選擇數據和日志的文件要壓縮的大小來執(zhí)行
DBCC SHRINKFILE (文件名)
GO
4.為了最大化的縮小日志文件(如果是sql 7.0,這步只能在查詢分析器中進行)
下面的示例分離 pubs,然后將 pubs 中的一個文件附加到當前服務器。
a.分離
EXEC sp_detach_db @dbname='庫名'
b.刪除日志LOG文件
c.再附加
復制代碼 代碼如下:
EXEC sp_attach_single_file_db @dbname='庫名',
@physname='c:\Program Files\Microsoft SQL Server\MSSQL\Data\庫名.mdf'
5.為了以后能自動收縮,做如下設置:
企業(yè)管理器--服務器--右鍵數據庫--屬性--選項--選擇"自動收縮"
--SQL語句設置方式:
復制代碼 代碼如下:
EXEC sp_dboption '庫名', 'autoshrink', 'TRUE'
6.如果想以后不讓它日志增長得太大
企業(yè)管理器--服務器--右鍵數據庫--屬性--事務日志
--將文件增長限制為xM(x是你允許的最大數據文件大小)
--SQL語句的設置方式:
alterdatabase 庫名 modify file(name=邏輯文件名,maxsize=20)
------分--隔-----
適用于SQL Server 2008的方法
[code]
USE [master]
GO
ALTER DATABASE DNName SET RECOVERY SIMPLE WITH NO_WAIT
GO
ALTER DATABASE DNName SET RECOVERY SIMPLE --簡單模式
GO
USE DNName
GO
DBCC SHRINKFILE (N'DNName_Log' , 11, TRUNCATEONLY)
GO
USE [master]
GO
ALTER DATABASE DNName SET RECOVERY FULL WITH NO_WAIT
GO
ALTER DATABASE DNName SET RECOVERY FULL --還原為完全模式
GO
[code]
相關文章
OBJECTPROPERTY與sp_rename更改對象名稱的介紹
開發(fā)過程中,錯誤免不了。為了糾正錯誤與規(guī)范化。可以使用MS SQL Server的系統(tǒng)存儲過程sp_rename與OBJECTPROPERTY來更改重命名2012-01-01sql server 2000中禁止創(chuàng)建表(權限設置方法)
最近發(fā)現數據庫中發(fā)現了三個臨時表,為了安全這里為大家分享下sql server 2000中禁止創(chuàng)建表的方法,網上都么有的,腳本之家小編原創(chuàng)2015-07-07數據庫觸發(fā)器DB2和SqlServer有哪些區(qū)別
大部分數據庫語句的基本語法是相同的,但具體到的每一種數據庫,又有些不一樣,例如觸發(fā)器,DB2和SQL Server兩種很大的不同。對數據庫觸發(fā)器DB2和SqlServer有哪些區(qū)別感興趣的朋友一起看看本文吧2015-11-11