SQL数据库太大。导致应用系统越来越慢。
大家好:
我在一家服装公司做。公司里面有一个进销存的软件。服务器是XEON3.0的,2G内存,3块160G SATA2硬盘。WIN2003系统,安装的是SQL2000 打的SP4的补丁。
这个进销存软件是个C/S系统,公司有15个客户端。外埠也有20多个客户端。数据交换量非常大(具体多少也没有统计过)。数据库增长的也非常迅速。现在大约有27 GB吧。系统也是越来越慢,客户端也反映打开一个界面也很慢。
我马上用大家经常用的一些方法进行收缩,压缩,减肥。可是效果不大。
请大家给帮帮忙。出出主意,有什么方法能使数据库减减肥。
我用WINRAR压缩备份的时候,压了整整一个小时。压完了以后发现才有800MB左右。
下面是我用的一些方法。可是不管用。大家看看,是不是还有更好的方法。
[1。凡事弄数据你都先备份,你别管它是嘛~~(备份你会的吧。。。。)
2。打开你的[查询分析器]--选择好你要减肥的数据库名称
3。运行代码:DUMP TRANSACTION [你要减肥的数据库名字] WITH NO_LOG(作用:清空日志)
4。运行代码:BACKUP LOG [你要减肥的数据库名字] WITH NO_LOG(作用:截断事务日志)
5。运行代码:DBCC SHRINKDATABASE([你要减肥的数据库名字])(作用:收缩数据库文件(如果不压缩,数据库的文件不会减小))
6。运行代码:DBCC UPDATEUSAGE (你要减肥的数据库名字) (作用:报告和更正 sysindexes 表的不正确内容) ]
1、清空日志
DUMP TRANSACTION 库名 WITH NO_LOG
2、截断事务日志
BACKUP LOG 数据库名 WITH NO_LOG
3、收缩数据库文件(如果不压缩,数据库的文件不会减小)
企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件
--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。
--选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。
也可以用SQL语句来完成:
--收缩数据库
DBCC SHRINKDATABASE(客户资料)
--收缩指定数据文件,1是文件号,可以通过这个语句查询到:
select * from sysfiles DBCC SHRINKFILE(1)
4、为了最大化的缩小日志文件(如果是sql 7.0,这步只能在查询分析器中进行)
a.分离数据库:
企业管理器--服务器--数据库--右键--分离数据库
b.在我的电脑中删除LOG文件
c.附加数据库:
企业管理器--服务器--数据库--右键--附加数据库
此法将生成新的LOG,大小只有500多K
或用代码:
下面的示例分离 pubs,然后将 pubs 中的一个文件附加到当前服务器。
a.分离
EXEC sp_detach_db @dbname = 'pubs'
b.删除日志文件
c.再附加:
EXEC sp_attach_single_file_db @dbname = 'pubs', @physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'
5、为了以后能自动收缩,做如下设置:
企业管理器--服务器--右键数据库--属性--选项--选择“自动收缩”
--SQL语句设置方式:
EXEC sp_dboption '数据库名', 'autoshrink', 'TRUE'
6、如果想以后不让它日志增长得太大。
企业管理器--服务器--右键数据库--属性--事务日志
--将文件增长限制为xM(x是你允许的最大数据文件大小)
--SQL语句的设置方式:
alter database 数据库名 modify file(name=逻辑文件名,maxsize=20)
以上就是我用的一些方法,也不乏网上一些能人高手给提供的,可就是不行。
希望这次大家帮帮我。谢谢大家。