DB2 清除表记录几种方式

本文介绍了四种清除DB2数据库中表数据的方法:使用TRUNCATE TABLE命令快速清空表内容;通过ALTER TABLE命令结合NOT LOGGED选项清空数据且不记录日志;利用IMPORT命令从空文件导入实现清空;采用LOAD命令从空文件加载数据到表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方法一:TRUNCATE 

TRUNCATE TABLE tabname IMMEDIATE

删除表内行

可 立即/延迟 释放存储

可 忽略/限定 DELETE触发器

可设定自增序列策略

Syntax

Read syntax diagramSkip visual syntax diagram
             .-TABLE-.              .-DROP STORAGE--.   
>>-TRUNCATE--+-------+--table-name--+---------------+----------->
                                    '-REUSE STORAGE-'   

   .-IGNORE DELETE TRIGGERS--------.   
>--+-------------------------------+---------------------------->
   '-RESTRICT WHEN DELETE TRIGGERS-'   

   .-CONTINUE IDENTITY-.              
>--+-------------------+--IMMEDIATE----------------------------><

参见:http://pic.dhe.ibm.com/infocenter/db2luw/v9r7/index.jsp?topic=%2Fcom.ibm.db2.luw.sql.ref.doc%2Fdoc%2Fr0053474.html


方法二:ALTER TABLE

ALTER TABLE tablename ACTIVATE NOT LOGGED INITIALLY WITH EMPTY TABLE

清空表数据,不记录日志

具体参见:http://pic.dhe.ibm.com/infocenter/db2luw/v9r7/topic/com.ibm.db2.luw.sql.ref.doc/doc/r0000888.html


方法三:IMPORT

IMPORT FROM anyemptyfile OF DEL/IXF REPLACE INTO tablename


方法四:LOAD

LOAD FROM anyemptyfile OF DEL REPLACE INTO schema.tabname NONRECOVERABLE

不建议使用,容易引起表空间或者表状态异常




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值