使用达思SQL数据库修复软件导出数据库时的接收数据的数据库如何清空表数据?

清空表数据,保留视图,存储过程,函数,以及保留表约束、触发器等等,可以给故障数据库预留一个好的躯壳,把坏库数据导入此躯壳。对用友、金蝶等数据库恢复有时候能达到好的效果。

清除表数据有两种方法:

一种用delete from [表名] ,这种方法对于大数据库,速度慢,会产生很大的日志信息,对于小库,速度可以忽略;

另一种是truncate table  [表名] ,这种方法速度快,但清除不了具有外键的表数据。

 

在清除表数据时,可以采用两种方法结合。

 

清除表数据时先禁用一切约束,清除完成以后再次启用约束就行了。

 

1、 采用truncate table  [表名] 清除表数据,排除具有外键属性的表,清除语句获取如下:

Use [要操作的库名字]

-----------------------------------------------------------------------

select

   'alter table  [' +name+ '] nocheck constraint all; alter table  [' +name + '] disable trigger all;

truncate table ['+name+'];'

 + ' alter table  [' +name + '] enable trigger all; alter table  [' +name + '] check constraint all;

 go'

 from sysobjects where id not in(select   parent_object_id from sys.foreign_keys ) and id not in(select   referenced_object_id from sys.foreign_keys ) and  type='U'

-----------------------------------------------------------------------

 

上述SQL语句得到的结果,再次在SQL查询分析器里运行。

 

2、用 delete from [表名] 清除表数据语句获取如下

Use [要操作的库名字]

-----------------------------------------------------------------------

SELECT 'alter table  [' +object_name (id) + '] nocheck constraint all; alter table  [' +object_name (id) + '] disable trigger all;

 delete from ['+object_name (id)+'];' + '

 alter table  [' +object_name (id) + '] enable trigger all; alter table  [' +object_name (id) + '] check constraint all;

go'

TableName from sysobjects where   type='U'

-----------------------------------------------------------------------

3、 有些MS SQL Server查询分析器,对于 上述语句后面的 go ,copy出来后不自动换行,可以把运行结果保存到文本文件中,查询分析器打开以后,会自动换行。如果不自动换行,sql语句执行报错。

4、 可能遇到清除不了的某些表,查看它和哪些表关联外键,先把两个表的约束同时禁用,再用delete from [表名],完了以后,两个表同时恢复约束使用。

5、 查看清除数据是否成功彻底,用下述语句查看记录数量:

Use [要操作的库名字]

-----------------------------------------------------------------------

SELECT object_name (i.id) TableName,

   rows as RowCnt

FROM sysindexes i

INNER JOIN sysObjects o

ON (o.id = i.id AND o.xType = 'U ')

WHERE indid < 2 and RowCnt>0

ORDER BY RowCnt desc

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
适用的数据库:8i, 9i数据库下该脚本通用<br/><br/>功能:导出一个用户的数据结构,包括表、视图、索引、约束、存储过程、触发器、函数、序列等等的定义,并且每个定义为一个文件<br/> 导出的各个对象的定义格式比较规范。<br/> 如表的定义为:<br/> prompt Create Table BBNACTIVEHISTORY<br/> CREATE TABLE test(<br/> USERID VARCHAR2(20) NOT NULL,<br/> SPUSERID VARCHAR2(30) NOT NULL,<br/> PRODUCTID VARCHAR2(20) NOT NULL,<br/> GAMETYPE NUMBER NOT NULL,<br/> STARTTIME DATE NOT NULL,<br/> CHARGED CHAR(1) default 'N' NOT NULL<br/> );<br/> <br/> 每个存储过程有多个参数,可以控制输出何种形式的内容,如可以只生成删除表的sql,可以在生成的创建表与索引的语句上加上storage子句等等。<br/><br/>运行 user_dll_sql.sql的准备工作:<br/><br/>1. 修改win_mkdir.bat文件,以便生成存放生成脚本的基本目录及其子目录<br/> win_mkdir.bat文件生成上面所需要的所有目录<br/> 打开win_mkdir.bat文件,修改BASE_DIC变量的值,如c:\temp\,该目录是存放生成的脚本文件的基本目录<br/> <br/> <br/>2. 运行 win_mkdir.bat文件创建必要的目录<br/><br/>3. 用sql*plus以想导出数据结构的用户登陆到数据库<br/> 运行user_dll_sql.sql 生成文件的路径文件,生成所有的ddl语句<br/> 运行文件,将存放生成脚本的基本目录作为参数(与步骤1改的基本目录一样)传入, ?要根据需要改为实际的目录<br/> SQL> @?\user_ddl_sql.sql c:\temp\<br/> <br/><br/>说明:<br/> 运行win_mkdir.bat,文件后,会自动在生成脚本的基本目录下产生如下目录:<br/> procedures, functions, triggers, packages, temp_sql.<br/> 每个目录的作用如下:<br/> procedures: 该目录存放存储过程, 有子目录separ_files, 该目录下的每个文件都是一个存储过程的源代码 <br/> functions: 该目录存放函数, 有子目录separ_files, 该目录下的每个文件都是一个函数的源代码<br/> triggers: 该目录存放触发器, 有子目录separ_files, 该目录下的每个文件都是一个触发器的源代码<br/> packages: 该目录存放包, 有子目录separ_files, 该目录下的每个文件都是一个包的源代码<br/> 有子目录separ_headbobdy_file, 该目录下的每个文件都是一个包的包头或包体的源代码<br/> temp_sql:存放生成的临文件<br/>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值