SQL Server清空日志及所有表的数据

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:
在查询分析器中顺序执行以下三步,其中   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  


 

近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL SERVER.
1.搜索出所有表名,构造为一条SQL语句

declare  @trun_name  varchar ( 8000 )
set  @trun_name = ''
select  @trun_name = @trun_name  +  ' truncate table  '  +  [ name ]  +  '  '  from  sysobjects  where  xtype = ' U '  and  status  >  0
exec  ( @trun_name )

该方法适合表不是非常多的情况,否则表数量过多,超过字符串的长度,不能进行完全清理.
2.利用游标清理所有表

declare  @trun_name  varchar ( 50 )
declare  name_cursor  cursor  for
select  ' truncate table  '  +  name  from  sysobjects  where  xtype = ' U '  and  status  >  0
open  name_cursor
fetch  next  from  name_cursor  into  @trun_name
while  @@FETCH_STATUS  =  0
begin
  
exec  ( @trun_name )
 
print  ' truncated table  '  +  @trun_name
 
fetch  next  from  name_cursor  into  @trun_name
end
close  name_cursor
deallocate  name_cursor

这是我自己构造的,可以做为存储过程调用, 能够一次清空所有表的数据,并且还可以进行有选择的清空表.
3.利用微软未公开的存储过程

exec  sp_msforeachtable " truncate  table  ?"

 

该方法可以一次清空所有表,但不能加过滤条件.

 

转载请注明出处[ http://samlin.cnblogs.com/] 
作者赞赏
 


刚做的招标网: 八爪鱼招标网 请大家多意见


本文转自Sam Lin博客博客园博客,原文链接:http://www.cnblogs.com/samlin/archive/2012/09/03/Sql_truncate_data.html,如需转载请自行联系原作者
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
1天前
|
SQL 数据库
Sql中如何添加数据
Sql中如何添加数据
5 0
|
1天前
|
SQL 存储 数据库连接
LabVIEW与SQL Server 2919 Express通讯
LabVIEW与SQL Server 2919 Express通讯
|
2天前
|
SQL Windows
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
12 4
|
3天前
|
SQL 数据可视化 Oracle
这篇文章教会你:从 SQL Server 移植到 DM(上)
这篇文章教会你:从 SQL Server 移植到 DM(上)
|
3天前
|
SQL 关系型数据库 数据库
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
|
3天前
|
SQL 存储 网络协议
SQL Server详细使用教程
SQL Server详细使用教程
23 2
|
3天前
|
SQL 存储 数据库连接
C#SQL Server数据库基本操作(增、删、改、查)
C#SQL Server数据库基本操作(增、删、改、查)
7 0
|
3天前
|
SQL 存储 小程序
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区。 数据库故障: 数据库文件丢失,主要涉及3个数据库,数千张表。数据库文件丢失原因未知,不能确定丢失的数据库文件的存放位置。数据库文件丢失后,服务器仍处于开机状态,所幸未写入大量数据。
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
|
4天前
|
SQL 存储 关系型数据库
SQL Server详细使用教程及常见问题解决
SQL Server详细使用教程及常见问题解决
|
5天前
|
SQL API 数据库
在Python中获取筛选后的SQL数据行数
在Python中获取筛选后的SQL数据行数
12 1