删除数据库日志文件的方法

  你曾经有在执行SQL的时候,数据库报事务日志已满,然后执行报错。然后纠结于怎么删除数据库日志,捣鼓半天吗,现在就提供两种删除日志文件的方法,希望能够帮到你!

  阅读目录

  • 方法一:手工操作

  • 方法二:存储过程代替手工操作

  • 示例存储过程下载

  回到顶部

  方法一:手工操作

  1.数据库-右键-属性-选项-恢复模式-由完成切换成简单

  2.数据库-右键-任务-收缩-文件-由完成切换成简单-文件类型-日志-将文件收缩到

  

 

  

 

  回到顶部

  方法二:存储过程代替手工操作

  --日志文件收缩至多少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.在数据库中执行上面的存储过程

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

  

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值