更新时间:2022-06-17 GMT+08:00

删除表中数据

在使用表的过程中,可能会需要删除已过期的数据,删除数据必须从表中整行的删除。

SQL不能直接访问独立的行,只能通过声明被删除行匹配的条件进行。如果表中有一个主键,用户可以指定准确的行。用户可以删除匹配条件的一组行或者一次删除表中的所有行。

使用DELETE命令删除行,如果删除表customer_t1中所有c_customer_sk为3869的记录:

1
DELETE FROM customer_t1 WHERE c_customer_sk = 3869;

删除表customer_t1中c_customer_sk为6885和4321的记录:

1
DELETE FROM customer_t1 WHERE c_customer_sk in (6885, 4321);

删除表customer_t1中c_customer_sk大于4000小于5000记录:

1
DELETE FROM customer_t1 WHERE c_customer_sk > 4000 and c_customer_sk < 5000;

如果执行如下命令,会删除表中所有的行。

1
DELETE FROM customer_t1;
1
TRUNCATE TABLE customer_t1;

全表删除的场景下,建议使用truncate,不建议使用delete。

删除创建的表:

1
DROP TABLE customer_t1;