zoukankan      html  css  js  c++  java
  • sql 压缩数据库出错

    问题:

      数据库 'XXX' 的事务日志已满。若要查明无法重用日志中的空间的原因,请参阅 sys.databases 中的 log_reuse_wait_desc 列。
    无法创建约束。

    解决方法:

      DUMP TRANSACTION 数据库名 WITH NO_LOG

      ALTER DATABASE 数据库名 SET RECOVERY SIMPLE

      然后再重新压缩一下数据库

    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时间太长可能影响生产的情况下使用。

  • 相关阅读:
    CentOS 7.X 关闭SELinux
    删除或重命名文件夹和文件的方法
    centos7-每天定时备份 mysql数据库
    centos7 tar.gz zip 解压命令
    MySQL5.6/5.7/8.0版本授权用户远程连接
    下载CentOS7系统
    使用js实现tab页签切换效果
    sql优化常用的几种方法
    mysql 多表联查的快速查询(索引)
    【图论】强连通分量+tarjan算法
  • 原文地址:https://www.cnblogs.com/amylis_chen/p/2054384.html
Copyright © 2011-2022 走看看