sql2000数据库和备份文件各占20G,怎样在保留数据的情况下减小占用空间,求高手解答!!!

sql2000数据库和备份文件各占20G,怎样在保留数据的情况下减小占用空间,求高手解答!!!,第1张

一般数据库不应该这么大。是事务日志文件很大吧。

所有对数据库执行的更新 *** 作都会记录在数据库的事务日志文件中,除非将数据库设为可自动收缩的或手动 的对数据库进行了收缩,否则事务日志文件将一直增长,直到达到事先设定的日志文件增长上限或用尽所有可用的磁盘空间。

如果当前的数据库文件或日志文件过大,可以使用以下两个命令对其进行收缩:DBCC SHRINKDATABASE:收缩指定数据库的所有数据和日志文件的大小

DBCC SHRINKFILE: 收缩数据库的某个指定数据或日志文件的大小 这两个命令可以释放数据库中的空闲空间,并将数据库或指定的数据库文件收缩到指定的大小。

SQL Server日志清空方法

在查询分析器中顺序执行以下三步,其中 databasename 为你的数据库文件名

1.清空日志:DUMP TRANSACTION databasename WITH NO_LOG

2.截断事务日志:BACKUP LOG databasename WITH NO_LOG

3.收缩数据库:DBCC SHRINKDATABASE(databasename)

--//////////////////////////////////////////////////////////////////

SQL Server日志清空方法

一种方法:清空日志。

1.打开查询分析器,输入命令 DUMP TRANSACTION 数据库名 WITH NO_LOG

2.再打开企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。

方法二:

清空日志:

------------------------------------------

BACKUP LOG 库名 WITH NO_LOG

DBCC SHRINKFILE( '日志文件名 ',新的大小数值型如1)

日志文件名是这样的:

select name from sysfiles

如:

mastlog

---------------------------------------------

backup log DATABASENAME

with truncate_only

dbcc shrinkdatabase (DATABASENAME,SIZE)

若每天有whole back up 的话可以设置一job,

每隔三天或一个星期清空一次

这样的话日志就不会长大了哦

-------------------------------------

1: 删除LOG

1:分离数据库

2:删除LOG文件

3:附加数据库

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

再将此数据库设置自动收缩

2:清空日志

DUMP TRANSACTION 库名 WITH NO_LOG

再:

企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了

方法三:

第一步:

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,具体意思看帮助。

方法四:

(这个方法在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不产生归档一样。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/6775531.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-28
下一篇2023-03-28

发表评论

登录后才能评论

评论列表(0条)

    保存