一般不建议做第4,6两步,第4步不安全,有可能损坏数据库或丢失数据。第6步如果日志达到上限,则以后的数据库处理会失败,在清理日志后才能恢复。

  1.清空日志

  DUMP TRANSACTION 库名 WITH NO_LOG

  2.截断事务日志

  BACKUP LOG 数据库名 WITH NO_LOG

  3.收缩数据库文件

  (如果不压缩,数据库的文件不会减小企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件

  选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了

  选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了,也可以用SQL语句来完成

  收缩数据库

  DBCC SHRINKDATABASE(客户资料)

  收缩指定数据文件,1是文件号,可以通过这个语句查询到:

  select*fromsysfiles

  DBCC SHRINKFILE(1)4.为了最大化的缩小日志文件(如果是sql 7.0,这步只能在查询分析器中进行)

  分离数据库:

  企业管理器--服务器--数据库--右键--分离数据库

  在我的电脑中删除LOG文件

  附加数据库:

  企业管理器--服务器--数据库--右键--附加数据库

  此法将生成新的LOG,大小只有500多K

  或用代码:

  下面的示例分离 pubs,然后将 pubs 中的一个文件附加到当前服务器。

  分离

  EXECsp_detach_db@dbname='pubs'

  删除日志文件

  再附加

  EXECsp_attach_single_file_db@dbname='pubs',
  @physname='c:\ProgramFiles\Microsoft
  SQLServer\MSSQL\Data\pubs.mdf'

  4.为了以后能自动收缩,做如下设置

  企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩"

  SQL语句设置方式:

  EXECsp_dboption'数据库名',
  'autoshrink','TRUE'

  5.如果想以后不让它日志增长得太大

  企业管理器--服务器--右键数据库--属性--事务日志

  将文件增长限制为xM(x是你允许的最大数据SQL Server 文件大小)

  SQL语句的设置方式:

  alter database 数据库名 modify file(name=逻辑文件名,maxsize=20)

这里小编为大家分享个我自己经常使用的方法:

DUMP TRANSACTION [jb51] WITH NO_LOGBACKUP LOG [jb51] WITH NO_LOGDBCC SHRINKDATABASE([jb51])

  以上的相关内容就是对SQL Server 压缩日志及数据库文件大小的介绍,望你能有所收获。

更多相关文章

  1. MySQL 5.7.9 服务无法启动-“NET HELPMSG 3534”的解决方法
  2. ES6 变量声明,箭头函数,数组方法,解构赋值,JSON,类与继承,模块化练习
  3. 浅谈Java中Collections.sort对List排序的两种方法
  4. Python list sort方法的具体使用
  5. python list.sort()根据多个关键字排序的方法实现
  6. android上一些方法的区别和用法的注意事项
  7. android实现字体闪烁动画的方法
  8. Android中dispatchDraw分析
  9. Android四大基本组件介绍与生命周期

随机推荐

  1. Android中贪吃蛇游戏的学习(四)
  2. SuperBrowser简单游览器Android
  3. android Fragment 学习资料推荐
  4. Android studio 启动出现错误AAPT: error
  5. Android 复习笔记之图解BroadcastReceive
  6. android aidl进程间通信
  7. android 获取应用程序占用的内存大小
  8. Android 杂记
  9. Java建造者模式,Android建造者模式的Alert
  10. Android中的ClassLoader与dex文件加密实