如何清空sql server 2000 中某个数据库的日志啊,好象备份是不行的。

ganry 2003-10-15 12:35:36
操作系统是Win 2000,急 啊
...全文
184 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
sdhdy 2003-10-20
  • 打赏
  • 举报
回复
--清除日志
方法1、
--在查询分析器,选中所要清理日志的数据库,执行如下SQL
backup log 数据库名 with no_log
DBCC SHRINKFILE ( 日志文件名或日志文件ID,要缩小的目标大小)

在当前数据库下
select fileid,groupid,name from sysfiles where groupid=0
----------------------------------------------------------
得到以下结果
fileid groupid name
2 0 test_log

以上结果,fileid为日志文件ID,name为test_log

你可以
backup log test with no_log
dbcc shrinkfile (2,2)
or
backup log test with no_log
dbcc shrinkfile ('test_log',2)
如果以后,不想要它变大,在数据库上点右键->属性->选项->故障恢复 模型 选择 简单模型就可以了!
或用SQL语句
alter database 数据库名 set recovery simple

方法2、
SQL SERVER企业管理器-》SQL SERVER组-》服务器-》数据库-》选中数据库实体-》右键-》所有任务-》分离数据库,
然后到数据库所在物理路径下删除.ldf文件,再数据库右键-》所有任务-》附加数据库,即可,会重新生成日志文件。
lga 2003-10-20
  • 打赏
  • 举报
回复
如无需一直保留,可作如下操作:
1、将数据库日志设为“自动收缩”
2、建议数据库维护计划,定期自动备份日志
shanshanzheng 2003-10-19
  • 打赏
  • 举报
回复
1.EXEC sp_detach_db 'dbname'
2.將log文件重新命名或轉移或刪除
3.EXEC sp_attach_single_file_db 'dbname', 'filename'

jingxijun 2003-10-16
  • 打赏
  • 举报
回复
用下面语句:
dump tran 库名 with no_log
豹子辰 2003-10-16
  • 打赏
  • 举报
回复
先把这个数据库分离以后附加到其他的注册里面去,然后写一份脚本,在你需要的地方用这个脚本重新建一个结构完全一样数据库。然后把所有数据导入到新建的数据库里面。由于这个数据库是新建的。所以日志就都没有啦。
ganry 2003-10-15
  • 打赏
  • 举报
回复
现在问题是这样的,由于日志满了,我就把数据库分离了,可能分离的时候不太彻底,那么我现在想附加又附加不上,象这种情况该怎么办啊?我想重新建立日志文件,如何来操作啊。
ganry 2003-10-15
  • 打赏
  • 举报
回复
第一步中存在问题,那就是他总是自动的找一个叫做相应的日志文件。用sp_attatch_db中如果不指定日志的话,他说物理设备有问题之类的话。
pengdali 2003-10-15
  • 打赏
  • 举报
回复
清空日志:
BACKUP LOG 库名 WITH NO_LOG

再:
企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了
CrazyFor 2003-10-15
  • 打赏
  • 举报
回复
清空日志:
BACKUP LOG 库名 WITH NO_LOG



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

日志文件名是这样的:

select name from sysfiles
如:
mastlog
txlicenhe 2003-10-15
  • 打赏
  • 举报
回复
1: 删除LOG
1:分离数据库 企业管理器->服务器->数据库->右键->分离数据库
2:删除LOG文件
3:附加数据库 企业管理器->服务器->数据库->右键->附加数据库
此法生成新的LOG,大小只有500多K
再将此数据库设置自动收缩
或用代码:
下面的示例分离 pubs,然后将 pubs 中的一个文件附加到当前服务器。

EXEC sp_detach_db @dbname = 'pubs'
EXEC sp_attach_single_file_db @dbname = 'pubs',
@physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'


2:清空日志
DUMP TRANSACTION 库名 WITH NO_LOG

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

27,579

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧