DB2数据库删除表
[大] [中] [小] 发布人:圣才学习网 发布日期:2012-09-26 16:41 共3276人浏览
DB2删除表操作相信大家都不陌生,这是我们最常用的操作之一,下面就对DB2删除表方面作详尽的阐述,供您参考学习。
DB2删除表
可以使用DROP TABLE语句删除表。当删除一个表时,也会删除SYSCAT.TABLES系统目录中包含有关该表的信息的那一行,并会影响从属于该表的任何其他对象。例如:
●会删除所有的列名
●会删除基于该表的任何列创建的索引
●将基于该表的所有视图标记为不可用
●删除的表和从属视图的所有特权被隐式撤销
●会删除在其中为该表父表或从属表的所有引用约束
●从属于删除的表的所有程序包和高速缓存的动态SQL和XQuery语句被标记为无效,且该状态会保持至重新创建了从属对象为止。这包括这样的一些程序包,它们从属于将被删除的层次结构中子表上的任何超表
●将从属于该删除表的所有触发器标记为不可用
要使用命令行来删除表,请输入:
DROP TABLE
以下语句删除DEPARTMENT表:
DROP TABLE DEPARTMENT
常用命令网站:
http://wenku.baidu.com/link?url=uZlj0FyyPoB3Ns8UIHUfxBIH1o_NeAhul6C76-C_YBfHsyOXxRgpl3peewxXZXk1tzMieg_Fv91TKOFz6K1AffsZgl4gwnqV7reMnFUD-Yu
DB2数据库系统建表后,难免会有将表中数据清空的需求,本文将为您介绍DB2数据库中四种数据删除的方法,供您参考,您可以根据实际情况来进行选择,希望能对有所帮助。
1. 使用 DELETE 语句,即:
DELETE FROM <表名>
该语句将清除表中所有数据,但由于这一操作会记日志,因此执行速度会相对慢一些,另外要注意的是,如果表较大,为保证删除操作的成功,应考虑是否留有足够大的日志空间。
2. 使用 NOT LOGGED INITIALLY 选项,即:
ALTER TABLE <表名> ACTIVATE NOT LOGGED INITIALLY WITH EMPTY TABLE
这一方法仅在所操作的表在创建时选择了 NOT LOGGED INITIALLY 选项进行定义后才可使用。整个删除操作将不会记日志,因此执行速度是几种方法中最快的一种,但删除的数据是不可恢复的。
3. 使用 IMPORT 或 LOAD 命令,即:
IMPORT FROM /dev/null OF DEL REPLACE INTO <表名> --(Unix 系统)
或 IMPORT FROM <空文件> OF DEL REPLACE INTO <表名>
LOAD FROM /dev/null OF DEL REPLACE INTO <表名> NONRECOVERABLE --(Unix 系统)
或 LOAD FROM <空文件> OF DEL REPLACE INTO <表名> NONRECOVERABLE
在这一方法中,REPLACE 导入方式首先会将表中所有数据清空,然后 IMPORT/LOAD 又向表中导入了空数据,从而实现了数据的清除操作。
4. 使用 DROP/CREATE TABLE 语句,即:
DROP TABLE