zoukankan      html  css  js  c++  java
  • sql server 清除日志

    SQL2008 的收缩日志 
    由于SQL2008对文件和日志管理进行了优化,所以以下语句在SQL2005中可以运行但在SQL2008中已经被取消:
    (SQL2005)
    Backup Log DNName with no_log
    go
    dump transaction DNName with no_log
    go
    USE DNName 
    DBCC SHRINKFILE (2)
    Go
    --------------------------------------------------------------
    (SQL2008):
    在SQL2008中清除日志就必须在简单模式下进行,等清除动作完毕再调回到完全模式。
    USE [master]
        GO
        ALTER DATABASE DNName SET RECOVERY SIMPLE WITH NO_WAIT
        GO
        ALTER DATABASE DNName SET RECOVERY SIMPLE   --简单模式
        GO
        USE DNName 
        GO
        DBCC SHRINKFILE (N'DNName_Log' , 11, TRUNCATEONLY)
        GO
        USE [master]
        GO
     
        ALTER DATABASE DNName SET RECOVERY FULL WITH NO_WAIT
     
        GO
     
        ALTER DATABASE DNName SET RECOVERY FULL  --还原为完全模式
     
        GO
     
    优点:此清除日志所运行消耗的时间短,90GB的日志在分钟左右即可清除完毕,做完之后做个完全备份在分钟内
    即可完成。
    缺点: 不过此动作最好不要经常使用,因为它的运行会带来系统碎片。普通状态下LOG和DIFF的备份即可截断日志。
    此语句使用的恰当环境:当系统的日志文件异常增大或者备份LOG时间太长可能影响生产的情况下使用。
     
    完整的收缩日志文件的 T-SQL 语句:
    BACKUP LOG xxdb to
    disk='x:work1.bak'
    DBCC SHRINKFILE
    (xxdb_log,10)
    GO

    --

    BACKUP LOG <db_name> to
    disk=<'backupfilename'>
    DBCC SHRINKFILE
    (<log_filename>,10)
    GO
    里面的x:work是随意设置的。当然也可以收缩到比如5M或1M。
  • 相关阅读:
    新人手册
    使用koa-mysql-session时报错
    自建windows服务器如何部署egg应用
    mac os 10.15 virtualBox6.0.12崩溃
    thinkphp3.2 上传图片兼容小程序
    PHP版本微信支付开发
    php mysql 按照指定年月查找数据 数据库create_time为时间戳
    Mac OS 查看端口和杀死进程
    MAC PHP7 如何disable xdebug
    TCP为什么是三次握手,为什么不是两次或者四次 && TCP四次挥手
  • 原文地址:https://www.cnblogs.com/101key/p/3484112.html
Copyright © 2011-2022 走看看