首页 > 数据库技术 > 详细

SQL存储过程删除数据库日志文件的方法

时间:2016-07-31 23:57:48      阅读:431      评论:0      收藏:0      [点我收藏+]
 --日志文件收缩至多少M
    DECLARE @DBLogSise AS INT
    SET @DBLogSise=0
    --查询出数据库对应的日志文件名称
    DECLARE @strDBName AS NVARCHAR(500)
    DECLARE @strLogName AS NVARCHAR(500)
    DECLARE @strSQL AS VARCHAR(1000)
    
    SELECT 
        @strLogName=B.name,
        @strDBName=A.name
    FROM master.sys.databases AS A
    INNER JOIN sys.master_files AS B
    ON A.database_id = B.database_id
    WHERE A.database_id=DB_ID() 
        
    SET @strSQL=‘
    --设置数据库恢复模式为简单
    ALTER DATABASE [‘+@strDBName+‘] SET RECOVERY SIMPLE;
    --收缩日志文件
    DBCC SHRINKFILE (‘‘‘+@strLogName+‘‘‘ , ‘+CONVERT(VARCHAR(20),@DBLogSise)+‘);
    --恢复数据库还原模式为完整
    ALTER DATABASE [‘+@strDBName+‘] SET RECOVERY FULL ‘
    exec(@strSQL)    


 1.在数据库中执行上面的存储过程名字为:usp_p_delDBLog

 2.然后再执行 EXEC dbo.usp_p_delDBLog @DBLogSise = 0 (收缩至多少M)

SQL存储过程删除数据库日志文件的方法

原文:http://www.cnblogs.com/xirilingfeng/p/5724103.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!