阅读排行榜

评论排行榜

最新评论

总感觉那个叫啥晓峰的回复,总是不那么切题,貌似只看到了最基础的用处 --【匿名用户】:E-works热心网友
这是个好建议! --【匿名用户】:E-works鐑績缃戝弸
所以国内企业要的就是灵活不是标准。 --【匿名用户】:E-works热心网友
写进BOM的都是标准成本,实际业务中按照标准成本来的有多少啊。 --【匿名用户】:E-works热心网友
这个有这个复杂? --【匿名用户】:E-works热心网友
建议还是挺好的。 --苌晓峰
这个分享还是蛮不错的吗! --苌晓峰
太简单了啊 --苌晓峰
分享 --苌晓峰
真正用得时候,谁还会想到这个啊 --苌晓峰

[推荐]清除SQL日志的方法
本文标签: SQL SBO 武汉达策 

客户上了系统后,数据日志总是长得很快,要不时地清除一下。大家可能不知道,经测试,删除数据比添加数据更加能产生日志。曾有人进行过测试:
        比如:
        _select* into test_2 from b_bgxx 共50000条记录,产生十几兆的,如果_deletefrom test_2,可以产生八十多兆的日志。
       掌握日志清除的方法很有用,有以下两种方法:
      方法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的日志文件。
发表于: 2010-06-02 17:45 秋声 阅读(927) 评论(0) 收藏 好文推荐

发表评论(网友发言只代表个人观点,不代表本网站观点或立场。)

您尚未登录,请先【登录或注册