zoukankan      html  css  js  c++  java
  • MSSQL 清空日志 删除日志文件

    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;

     
     
     
    标签: MSSQL
  • 相关阅读:
    Python学习笔记(四)多进程的使用
    Python学习笔记(三)多线程的使用
    windows无法安装msi文件
    标签传播算法
    信息论基础
    模块度Q
    HTTPS开发(SSL--用Tomcat服务器配置https双向认证)
    oracle 优化
    eclipse 界面开发--windowbuilder
    vba 读取数据库
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3170495.html
Copyright © 2011-2022 走看看