资源描述:
《sql数据库如何定期收缩日志文件大小》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、sql数据库如何定期收缩日志文件大小--用作业就行了嘛:企业管理器--管理--SQL Server代理--右键作业--新建作业--"常规"项中输入作业名称--"步骤"项--新建--"步骤名"中输入步骤名--"类型"中选择"Transact-SQL 脚本(TSQL)"--"数据库"选择执行命令的数据库--"命令"中输入日志收缩的语句:DUMP TRANSACTION 库名 WITH NO_LOG 截断事务日志BACKUP LOG 数据库名 WITH NO_LOG收缩数据库DBCC SHRINKDAT
2、ABASE(数据库名)--确定--"调度"项--新建调度--"名称"中输入调度名称--"调度类型"中选择你的作业执行安排--如果选择"反复出现"--点"更改"来设置你的时间安排然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行/--特别注意请按步骤进行,未进行前面的步骤,请不要做后面的步骤否则可能损坏你的数据库.一般不建议做第4,6两步第4步不安全,有可能损坏数据库或丢失数据第6步如果日志达到上限,则以后的数据库处理会失败,在清理日志后才能恢复.--/--下面的所有库名都指
3、你要处理的数据库的库名1.清空日志DUMPTRANSACTION库名WITHNO_LOG2.截断事务日志:BACKUPLOG库名WITHNO_LOG3.收缩数据库文件(如果不压缩,数据库的文件不会减小企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了--选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了也
4、可以用SQL语句来完成--收缩数据库DBCCSHRINKDATABASE(库名)--收缩指定数据文件,1是文件号,可以通过这个语句查询到:selectfromsysfilesDBCCSHRINKFILE(1)4.为了最大化的缩小日志文件(如果是sql7.0,这步只能在查询分析器中进行)a.分离数据库:企业管理器--服务器--数据库--右键--分离数据库b.在我的电脑中删除LOG文件c.附加数据库:企业管理器--服务器--数据库--右键--附加数据库此法将生成新的LOG,大小只有500多K或用代码:
5、下面的示例分离pubs,然后将pubs中的一个文件附加到当前服务器。a.分离EXECsp_detach_db@dbname='库名'b.删除日志文件c.再附加EXECsp_attach_single_file_db@dbname='库名',@physname='c:ProgramFilesMicrosoftSQLServerMSSQLData库名.mdf'5.为了以后能自动收缩,做如下设置:企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩"--SQL语句设置方式:EX
6、ECsp_dboption'库名','autoshrink','TRUE'6.如果想以后不让它日志增长得太大企业管理器--服务器--右键数据库--属性--事务日志--将文件增长限制为xM(x是你允许的最大数据文件大小)--SQL语句的设置方式:alterdatabase库名modifyfile(name=逻辑文件名对我有用[0]丢个板砖[0]引用举报管理TOP精华推荐:SQLSERVER性能优化综述rainbow3(北京彩虹)等级:#4楼得分:0回复于:2005-11-0313:12:52哈哈,真
7、的可以阿!从80G一下到了1.98M,太感谢了!!!!!!请按步骤进行,未进行前面的步骤,请不要做后面的步骤否则可能损坏你的数据库.一般不建议做第4,6两步第4步不安全,有可能损坏数据库或丢失数据第6步如果日志达到上限,则以后的数据库处理会失败,在清理日志后才能恢复.--/--下面的所有库名都指你要处理的数据库的库名1.清空日志DUMPTRANSACTION库名WITHNO_LOG2.截断事务日志:BACKUPLOG库名WITHNO_LOG3.收缩数据库文件(如果不压缩,数据库的文件不会减小企业管
8、理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了--选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了也可以用SQL语句来完成--收缩数据库DBCCSHRINKDATABASE(库名)--收缩指定数据文件,1是文件号,可以通过这个语句查询到:selectfromsysfilesDBCCSHRI