MSSQL 清空日志 删除日志文件
最近的项目主要做数据的归档,把数据从一个数据库拉到另一个数据库mssql数据库日志,照成新数据库的日志文件非常大;于是想把日志文件删除。最简单就是先分离数据库-》删除日志文件-》最后附加数据,我这里需要在SSIS中调用, 大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说MSSQL 清空日志 删除日志文件,希望能够帮助大家进步!!! 最近的项目主要做数据的归档,把数据从一个数据库拉到另一个数据库,照成新数据库的日志文件非常大;于是想把日志文件删除。最简单就是先分离数据库-》删除日志文件-》最后附加数据,我这里需要在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) (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |