MSSQL数据库日志清除方法

如题

MS SQL数据库在日志满了后会导致程序运行时出现错误,只有清除日志后,才能正常运行,下面是本站提供得工具和方法,使用该工具,本站的合租用户均可自行清除MS SQL数据库的日志。

1、从以下地址下载MsSql数据库清除工具。
http://www.txdns.cn/MssqlLogDel.rar

2、下载解压后,有个ASP文件(MssqlLogDel.asp),用文本编辑器打开该文件,修改以下几行代码中的数据库相关配置:
Const SqlDatabaseName = dbname
Const SqlPassword = dbpass
Const SqlUsername = dbuser
Const SqlLocalName = (local)

dbname改成你开通的mssql数据库名称
dbpass改成你开通的mssql数据库访问密码
dbuser改成你开通的mssql数据库访问用户名
(local)改成你开通的mssql数据库服务器地址,如果数据库在和该程序在同一服务器,则不需要修改,用(local)即可。

3、将MssqlLogDel.asp上传到你的网站任意目录下,然后通过浏览器访问该文件即可清除数据库日志。譬如你放在网站http www.abc.com的根目录下,则在浏览器中输入地址:http//:www.abc.com/MssqlLogDel.asp后访问,即可清除你的数据库日志。

注意:
1、只有MSsql数据库需要清除日志,MYSQL数据库不需要清除日志。
2、该程序只能在支持Asp的网站使用
3、为了安全,日志清除后,请将MssqlLogDel.asp删除,下次使用时再次上传即可。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-08-13
方法1:
第一步:
backup log database_name with no_log
或者 backup log database_name with truncate_only --no_log和truncate_only是在这里是同义的,随便执行哪一句都可以
第二步:
1.收缩特定数据库的所有数据和日志文件,执行 dbcc shrinkdatabase (database_name,[,target_percent])--database_name是要收缩的数据库名称;target_percent是数据库收缩后的数据库文件中所要的剩余可用空间百分比
2.收缩一次一个特定数据库中的数据或日志文件,执行 dbcc shrinkfile(file_id,[,target_size]) --file_id是要收缩的文件的标识 (ID) 号,若要获得文件 ID,请使用 FILE_ID 函数或在当前数据库中搜索 sysfiles;target_size是用兆字节表示的所要的文件大小(用整数表示)。如果没有指定,dbcc shrinkfile 将文件大小减少到默认文件大小

两个dbcc都可以带上参数notruncate或truncateonly,具体意思看帮助。

方法2
(这个方法在sqlserver2000的环境下做一般能成功,在sqlserver7及以下版本就不一定了):
第一步:
先备份整个数据库以备不测
第二步:
备份结束后,在Query Analyzer中执行如下的语句:
exec sp_detach_db yourDBName,true --卸除这个DB在MSSQL中的注册信息
第三步:
到日志的物理文件所在的目录中去删除该日志文件或者将该日志文件移出该目录
第四步:
在Query Analyzer中执行如下的语句:
exec sp_attach_single_file_db yourDBName,'d:\mssql7\data\yourDBName_data.mdf'
--以单文件的方式注册该DB,如果成功则MSSQL将自动为这个DB生成一个500K的日志文件。

以上方法在清除log日志中均有效。
但,能否让sql server 不产生log日志呢?以上方法好像均无效。
我这儿正好有个case:
我客户的sql server每天都会产生4,500M的log日志,每天都清除一下,非常不便。有没有办法实现不产生log日志呢?

我分析了一下客户产生log日志的原因,并且做了相应测试。
客户是每天将数据库清空,从总系统中将数据导入到sql server里。我感决sqlserver在插入时产生log不大,在delete整个库时产生log极大。
比如:
SELECT * into test_2 from b_bgxx
共45000条记录,产生十几M log,如果
delete from test_2
产生80多M log ,这明显存在问题。

虽然可以换成:
truncate table test_2
但我还是希望能找到不产生log的方法。就如oracle不产生归档一样