SQL数据库日志文件,可以删除吗

SQL数据库日志文件,可以删除吗,第1张

可以的

打开 SQL Server Management Studio并连接到数据库引擎数据库。

在“对象资源管理器”窗格中展开“数据库”节点。

右击要修改的数据库,在d出的快捷菜单中选择“属性”命令,打开“数据库属性”,对话框,选择“文件”选项,显示文件设置界面。

若要添加文件,单击“添加”按钮,在“数据库文件”列表框中将出现一个新的文件,设置该文件的各个参数即可。

若要删除文件,选中要删除的文件后单击“删除”按钮即可。需要注意的是,删除数据文件和日志文件时,必须确保文件里面不能包含数据或日志,即是空文件。

完成相应的 *** 作后,单击“确定”按钮。

参考资料

SQL数据库日志文件,可以删除吗?百度经验[引用时间2018-1-3]

教你如何清除SQL日志

1.打开查询分析器,输入命令

DUMP TRANSACTION 数据库名 WITH NO_LOG

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

清除Log有两种方法:

1自动清除法

开放数据库选项 Trunc Log on Chkpt,使数据库系统每隔一段时间自动清除Log。此方法的优点是无须人工干预,由SQL Server自动执行,并且一般不会出现Log溢满的情况;缺点是只清除Log而不做备份。

2手动清除法

执行命令“dump transaction”来清除Log。以下两条命令都可以清除日志:

dump transaction with truncate_only

dump transaction with no_log

通常删除事务日志中不活跃的部分可使用“dump transaction with trancate_only”命令,这条命令写进事务日志时,还要做必要的并发性检查。SYBASE提供“dump transaction with no_log”来处理某些非常紧迫的情况,使用这条命令有很大的危险性,SQL Server会d出一条警告信息。为了尽量确保数据库的一致性,你应将它作为“最后一招”。

以上两种方法只是清除日志,而不做日志备份,若想备份日志,应执行“dump transaction database_name to dumpdevice”命令。

清除后对数据库没有影响

在SQL Server运行中,只能“清空”和“收缩”事务日志文件,不能删除它。

相关知识点延伸:

1、在当前的SQL Server中,事务日志文件在数据库运行中必需存在。如果是事务文件过大,想减少磁盘中用的话,可以清空事务日志,并收缩事务日志文件。

2、想删除数据库事务日志文件,只能先“分离”数据库,不过,在附加时如果数据库文件的事务日志文件缺失,将会在附加时重建。

3、相关 *** 作:

a清空日志

DUMP TRANSACTION 库名 WITH NO_LOG

b截断事务日志:

BACKUP LOG 数据库名 WITH NO_LOG

c收缩数据库文件(如果不收缩,数据库的文件不会减小

企业管理器->右键你要压缩的数据库->所有任务->收缩数据库->收缩文件

填入收缩数值,后确定。

1、确定SQL数据库安装路径与所用SQL数据库名称

2、点击开始--程序--Microsoft

SQL

Server--查询分析器--确定进入软件里点击菜单帮助--Transact-sql帮助(S)--索引--输入(sp_attach_single_file_db),右边对框里找下命令或者空白处直接输入下命令:

EXEC

sp_detach_db

@dbname

=

'pubs'returnEXEC

sp_attach_single_file_db

@dbname

=

'pubs',

@physname

=

'c:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\pubsmdf'

注意:return加入命令语名数据库(LDF与MDF)分离再数据库名改回所要选即pubs改J2002即:

EXEC

sp_detach_db

@dbname

=

'

J2002'returnEXEC

sp_attach_single_file_db

@dbname

=

'

J2002',

@physname

=

'c:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\

J2002mdf'

3、输入命令点击菜单查询--执行下面对框出现命令"命令已成功完成"

4、删除命令(EXEC

sp_detach_db

@dbname

=

'

J2002'

return)进入安装SQL数据库路径里J2002ldf文件重命名

5、接着第3点开始点击菜单查询--执行下面对框出现命令"设备激活错误物理文件名

'C:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\J200188ldf'

能有误已创建名

'c:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\j200188_logLDF'

新日志文件"

backup log DB_Name with no_log方法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_datamdf'

--以单文件的方式注册该DB,如果成功则MSSQL将自动为这个DB生成一个500K的日志文件。

以上方法在清除log日志中均有效。

但,能否让sql server 不产生log日志呢?以上方法好像均无效。

我这儿正好有个case:

我分析了一下客户产生log日志的原因,并且做了相应测试。

客户是每天将数据库清空,从总系统中将数据导入到sql server里。我感决sqlserver在插入时产生log不大,在delete整个库时产生log极大。

比如:SELECT into test_2 from b_bgxx

共45000条记录,产生十几M log,如果

delete from test_2

产生80多M log ,这明显存在问题。

虽然可以换成:

但我还是希望能找到不产生log的方法。就如oracle不产生归档一样。

使用LogExplorer查看和恢复数据LogExplorer4

1

可用于SQLServer2005的日志查看工具下载地址:download

csdn

net/source/620271使用方法:打开LogExplorer->AttachLogFile->选择SQLServer服务器和登陆方式->Connect->在DatabaseName中选择数据库->Attach->左面对话框中Browse->ViewLog->就可以看到log记录了

以上就是关于SQL数据库日志文件,可以删除吗全部的内容,包括:SQL数据库日志文件,可以删除吗、如何清除SQL数据库日志,清除后对数据库有什么影响、sql server运行中,是否能删除主数据库事务日志文件等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存