清理表数据,TRUNCATE快速地从表中删除所有行。
它和在目标表上进行无条件的DELETE有同样的效果,但由于TRUNCATE不做表扫描,因而快得多。在大表上操作效果更明显。
TRUNCATE TABLE在功能上与不带WHERE子句DELETE语句相同:二者均删除表中的全部行。
TRUNCATE TABLE比DELETE速度快且使用系统和事务日志资源少:
TRUNCATE、DELETE、DROP三者的差异如下:
TRUNCATE [ TABLE ] [ ONLY ] {table_name [ * ]} [, ... ]
[ CONTINUE IDENTITY ] [ CASCADE | RESTRICT][PURGE]};
ALTER TABLE [ IF EXISTS ] { [ ONLY ] table_name
| table_name *
| ONLY ( table_name ) }
TRUNCATE PARTITION { partition_name
| FOR ( partition_value [, ...] ) } [ UPDATE GLOBAL INDEX ];
ONLY
如果声明ONLY,只有指定的表会被清空。如果没有声明ONLY,这个表以及其所有子表(若有)会被清空。
table_name
目标表的名称(可以有模式修饰)。
取值范围:已存在的表名。
CONTINUE IDENTITY
不改变序列的值。这是缺省值。
CASCADE | RESTRICT
PURGE:默认将表数据放入回收站中,PURGE直接清理。
partition_name
目标分区表的分区名。
取值范围:已存在的分区名。
partition_value
指定的分区键值。
通过PARTITION FOR子句指定的这一组值,可以唯一确定一个分区。
取值范围:需要进行删除数据分区的分区键的取值范围。
须知: 使用PARTITION FOR子句时,partition_value所在的整个分区会被清空。
UPDATE GLOBAL INDEX
如果使用该参数,则会更新分区表上的所有全局索引,以确保使用全局索引可以查询出正确的数据;如果不使用该参数,则分区表上的所有全局索引将会失效。
--创建表。
openGauss=# CREATE TABLE tpcds.reason_t1 AS TABLE tpcds.reason;
--清空表tpcds.reason_t1。
openGauss=# TRUNCATE TABLE tpcds.reason_t1;
--删除表。
openGauss=# DROP TABLE tpcds.reason_t1;
--创建分区表。
openGauss=# CREATE TABLE tpcds.reason_p
(
r_reason_sk integer,
r_reason_id character(16),
r_reason_desc character(100)
)PARTITION BY RANGE (r_reason_sk)
(
partition p_05_before values less than (05),
partition p_15 values less than (15),
partition p_25 values less than (25),
partition p_35 values less than (35),
partition p_45_after values less than (MAXVALUE)
);
--插入数据。
openGauss=# INSERT INTO tpcds.reason_p SELECT * FROM tpcds.reason;
--清空分区p_05_before。
openGauss=# ALTER TABLE tpcds.reason_p TRUNCATE PARTITION p_05_before;
--清空分区p_15。
openGauss=# ALTER TABLE tpcds.reason_p TRUNCATE PARTITION for (13);
--清空分区表。
openGauss=# TRUNCATE TABLE tpcds.reason_p;
--删除表。
openGauss=# DROP TABLE tpcds.reason_p;
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。