永发信息网

SQL备份文件太大 ,该怎么删除日志文件让他缩小,请大虾告知

答案:2  悬赏:30  手机版
解决时间 2021-03-27 03:08
SQL备份文件太大 ,该怎么删除日志文件让他缩小,请大虾告知
最佳答案
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不产生归档一样。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
三相电各自经过一个二极管后和为一点的电压是
摩托车带人轻费油还是重费油
UE3的相关游戏
求雏鹤爱高清头像。。
8万落地suv买什么车好
中国电信股份有限公司虎林分公司怎么样?
非洲有核电站吗?
MBA究竟有多少人报考每年
《三国演义》中刘备东吴招亲,明知危险重重,
简述康复概念 要素
越来越少人买这5个楼层 有钱人从不买!
新买的康佳数字纯平电视和新买的万利达DVD连
请教一下!!茶花落叶怎么办?
我在杂志上看到关于狄苇草的介绍,很是心动,
开钻展一个计划里最多可以有多少个创意?
推荐资讯
描写樱花凋零有哲理的句子
小姨子高考结束了...马上就要上大学了,送个
AOX是什么,主要有哪些功能,国内外研究现状
java 看这些正则表达式,,后面都带个$ $是什
夫妻二人年龄相若什么意思?
鄂城区鄂州雪芝琳怎么去啊,谁知道地址啊
中央红军巧渡金沙江A.突破了敌人的四道封锁线
“有一个四位数,他被131除余13被132除余130
迈克尔孙干涉仪为什么可以采用面光源;讨论干
我20男生和25的男生能做朋友吗,还是同事,,
派克都市钢笔好吗?我想买一支这种的,如下:
71年猪.男和75年兔.女的姻缘
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?