您好,欢迎来到思海网络,我们将竭诚为您提供优质的服务! 诚征网络推广 | 网站备案 | 帮助中心 | 软件下载 | 购买流程 | 付款方式 | 联系我们 [ 会员登录/注册 ]
促销推广
客服中心
业务咨询
有事点击这里…  531199185
有事点击这里…  61352289
点击这里给我发消息  81721488
有事点击这里…  376585780
有事点击这里…  872642803
有事点击这里…  459248018
有事点击这里…  61352288
有事点击这里…  380791050
技术支持
有事点击这里…  714236853
有事点击这里…  719304487
有事点击这里…  1208894568
有事点击这里…  61352289
在线客服
有事点击这里…  531199185
有事点击这里…  61352288
有事点击这里…  983054746
有事点击这里…  893984210
当前位置:首页 >> 技术文章 >> 文章浏览
技术文章

SQL Server 日志操作相关代码

添加时间:2014-11-4 16:43:51  添加: 思海网络 

方法一:

--让日志不再增长,但是不能压缩日志 
EXEC sp_dboption 'your_dbname', 'trunc. log', 'TRUE'

方法二:

--超强数据库文件及日志文件压缩, 
--压缩后可能会导致数据库不能正常访问,重启一下数据库即可 
DUMP TRANSACTION [数据库名] WITH NO_LOG 
BACKUP LOG [数据库名] WITH NO_LOG 
DBCC SHRINKDATABASE([数据库名])


方法三:


经常在CSDN上看到网友发帖说,压缩日志文件处理不当,导致数据库损坏,甚至不能恢复数据,于是就写了一个通用的数据库日志文件压缩的存储过程来解决此问题: 

/**//*--压缩数据库的通用存储过程 

压缩日志及数据库文件大小 
因为要对数据库进行分离处理 
所以存储过程不能创建在被压缩的数据库中 

--邹建 2004.3--*/ 

/**//*--调用示例 
exec p_compdb 'test' 
--*/ 

use master --注意,此存储过程要建在master数据库中 
go 

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_compdb]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) 
drop procedure [dbo].[p_compdb] 
GO 

create proc p_compdb 
@dbname sysname, --要压缩的数据库名 
@bkdatabase bit=1, --因为分离日志的步骤中,可能会损坏数据库,所以你可以选择是否自动数据库 
@bkfname nvarchar(260)='' --备份的文件名,如果不指定,自动备份到默认备份目录,备份文件名为:数据库名+日期时间 
as 
--1.清空日志 
exec('DUMP TRANSACTION ['+@dbname+'] WITH NO_LOG') 

--2.截断事务日志: 
exec('BACKUP LOG ['+@dbname+'] WITH NO_LOG') 

--3.收缩数据库文件(如果不压缩,数据库的文件不会减小 
exec('DBCC SHRINKDATABASE(['+@dbname+'])') 

--4.设置自动收缩 
exec('EXEC sp_dboption '''+@dbname+''',''autoshrink'',''TRUE'''

--后面的步骤有一定危险,你可以可以选择是否应该这些步骤 
--5.分离数据库 
if @bkdatabase=1 
begin 
if isnull(@bkfname,'')='' 
set @bkfname=@dbname+'_'+convert(varchar,getdate(),112) 
+replace(convert(varchar,getdate(),108),':','') 
select 提示信息='备份数据库到SQL 默认备份目录,备份文件名:'+@bkfname 
exec('backup database ['+@dbname+'] to disk='''+@bkfname+''''
end 

--进行分离处理 
create table #t(fname nvarchar(260),type int) 
exec('insert into #t select filename,type=status&0x40 from ['+@dbname+']..sysfiles') 
exec('sp_detach_db '''+@dbname+''''

--删除日志文件 
declare @fname nvarchar(260),@s varchar(8000) 
declare tb cursor local for select fname from #t where type=64 
open tb 
fetch next from tb into @fname 
while @@fetch_status=0 
begin 
set @s='del "'+rtrim(@fname)+'"' 
exec master..xp_cmdshell @s,no_output 
fetch next from tb into @fname 
end 
close tb 
deallocate tb 

--附加数据库 
set @s='' 
declare tb cursor local for select fname from #t where type=0 
open tb 
fetch next from tb into @fname 
while @@fetch_status=0 
begin 
set @s=@s+','''+rtrim(@fname)+'''' 
fetch next from tb into @fname 
end 
close tb 
deallocate tb 
exec('sp_attach_single_file_db '''+@dbname+''''+@s
go 

关键字:SQL Server、数据库、日志
分享到:

顶部 】 【 关闭
版权所有:佛山思海电脑网络有限公司 ©1998-2024 All Rights Reserved.
联系电话:(0757)22630313、22633833
中华人民共和国增值电信业务经营许可证: 粤B1.B2-20030321 备案号:粤B2-20030321-1
网站公安备案编号:44060602000007 交互式栏目专项备案编号:200303DD003  
察察 工商 网安 举报有奖  警警  手机打开网站