MSSQL 清空日志 删除日志文件
2013-07-03 18:47
519 查看
最近的项目主要做数据的归档,把数据从一个数据库拉到另一个数据库,照成新数据库的日志文件非常大;于是想把日志文件删除。最简单就是先分离数据库-》删除日志文件-》最后附加数据,我这里需要在SSIS中调用,所以已sql脚本为主。首先我们需要获取数据库文件的路径:
declare @logfilename varchar(100)
declare @datafilename varchar(100)
select @logfilename=physical_name from sys.database_files where type=1
select @datafilename=physical_name from sys.database_files where type=0
然后切换到master下,分离数据库
use master
exec sp_detach_db @dbname='TestVFA';
紧接下来就是删除数据库 日志文件
----Remove file
DECLARE @Result int
DECLARE @FSO_Token int
EXEC @Result = sp_OACreate 'Scripting.FileSystemObject', @FSO_Token OUTPUT
EXEC @Result = sp_OAMethod @FSO_Token, 'DeleteFile', NULL, @logfilename
EXEC @Result = sp_OADestroy @FSO_Token
最后就是附加数据库
exec sp_attach_single_file_db @dbname='TestVFA',@physname=@datafilename
注意:默认Ole Automation Procedures 是禁用的我们需要启用它
exec sp_configure 'show advanced options', 1;
RECONFIGURE;
exec sp_configure 'Ole Automation Procedures',1;
RECONFIGURE;
在实际项目中,我们往往会把数据库的初始化大小设置的比较大,为了缩小这个初始化大小可以采用收缩数据,如
DBCC SHRINKDATABASE(VFAsia)
DBCC SHRINKFILE(1)
declare @logfilename varchar(100)
declare @datafilename varchar(100)
select @logfilename=physical_name from sys.database_files where type=1
select @datafilename=physical_name from sys.database_files where type=0
然后切换到master下,分离数据库
use master
exec sp_detach_db @dbname='TestVFA';
紧接下来就是删除数据库 日志文件
----Remove file
DECLARE @Result int
DECLARE @FSO_Token int
EXEC @Result = sp_OACreate 'Scripting.FileSystemObject', @FSO_Token OUTPUT
EXEC @Result = sp_OAMethod @FSO_Token, 'DeleteFile', NULL, @logfilename
EXEC @Result = sp_OADestroy @FSO_Token
最后就是附加数据库
exec sp_attach_single_file_db @dbname='TestVFA',@physname=@datafilename
注意:默认Ole Automation Procedures 是禁用的我们需要启用它
exec sp_configure 'show advanced options', 1;
RECONFIGURE;
exec sp_configure 'Ole Automation Procedures',1;
RECONFIGURE;
在实际项目中,我们往往会把数据库的初始化大小设置的比较大,为了缩小这个初始化大小可以采用收缩数据,如
DBCC SHRINKDATABASE(VFAsia)
DBCC SHRINKFILE(1)
相关文章推荐
- MSSQL 清空日志 删除日志文件
- MSSQL 清空日志 删除日志文件
- [MSSQL]SQL Server 2008 收缩日志 清空删除大日志文件
- MSSQL 2005,2008,2012收缩清空删除大日志文件
- MSSQL 清空日志 删除日志文件
- 清空删除mssql数据库日志原文网址:http://admin.88443.net/article.
- 收缩、清空和删除SQL Server数据库文件及日志文件
- SQL Server 2008 收缩日志 清空删除大日志文件
- SQL Server 2008 收缩日志 清空删除大日志文件 转载
- SQL Server 2008 清空删除日志文件 130G日志 10秒内变10M .
- SQL Server 2008 清空删除日志文件(瞬间日志变几M)
- SQL Server 2008 清空删除日志文件
- Linux删除(清空)正在运行的应用日志文件内容
- mssql2008清空日志文件
- SQL Server 2008 收缩日志 清空删除大日志文件
- SQL Server 2008 收缩日志 清空删除大日志文件
- mssql2008清空日志文件
- Linux删除(清空)正在运行的应用日志文件内容
- SQL Server 2008 清空删除日志文件
- MSSQL2008 收缩日志 清空大日志文件