TRUNCATE 语句

Batch

TRUNCATE 语句用于删除表中的全部数据,但不会删除表本身。

注意 目前, TRUNCATE 语句仅支持批模式, 并且要求目标表实现了 SupportsTruncate 接口。 如果在一个没有实现该接口的表上执行 TRUNCATE 语句,则会抛异常。

执行 TRUNCATE 语句

Java

可以使用 TableEnvironmentexecuteSql() 方法执行 TRUNCATE 语句。如果 TRUNCATE 操作执行失败,executeSql() 方法会抛出异常。

以下示例展示了如何在 TableEnvironment 中执行一条 TRUNCATE 语句。

Scala

可以使用 TableEnvironment 中的 executeSql() 方法执行 TRUNCATE 语句。如果 TRUNCATE 操作执行失败,executeSql() 方法会抛出异常。

以下的例子展示了如何在 TableEnvironment 中执行一条 TRUNCATE 语句。

Python

可以使用 TableEnvironment 中的 execute_sql() 方法执行 TRUNCATE 语句。如果 TRUNCATE 操作执行失败,execute_sql() 方法会抛出异常。

以下的例子展示了如何在 TableEnvironment 中执行一条 TRUNCATE 语句。

SQL CLI

TRUNCATE 语句可以在 SQL CLI 中执行。

以下示例展示了如何在 SQL CLI 中执行一条 TRUNCATE 语句。

Java

  1. EnvironmentSettings settings = EnvironmentSettings.newInstance().inBatchMode().build();
  2. TableEnvironment tEnv = TableEnvironment.create(settings);
  3. // 注册 "Orders" 表
  4. tEnv.executeSql("CREATE TABLE Orders (`user` STRING, product STRING, amount INT) WITH (...)");
  5. // 插入数据
  6. tEnv.executeSql("INSERT INTO Orders VALUES ('Lili', 'Apple', 1), ('Jessica', 'Banana', 2), ('Mr.White', 'Chicken', 3)").await();
  7. tEnv.executeSql("SELECT * FROM Orders").print();
  8. // +--------------------------------+--------------------------------+-------------+
  9. // | user | product | amount |
  10. // +--------------------------------+--------------------------------+-------------+
  11. // | Lili | Apple | 1 |
  12. // | Jessica | Banana | 2 |
  13. // | Mr.White | Chicken | 3 |
  14. // +--------------------------------+--------------------------------+-------------+
  15. // 3 rows in set
  16. // 清理 "Orders" 表数据
  17. tEnv.executeSql("TRUNCATE TABLE Orders").await();
  18. tEnv.executeSql("SELECT * FROM Orders").print();
  19. // 返回空结果

Scala

  1. val env = StreamExecutionEnvironment.getExecutionEnvironment()
  2. val settings = EnvironmentSettings.newInstance().inBatchMode().build()
  3. val tEnv = StreamTableEnvironment.create(env, settings)
  4. // 注册一个 "Orders" 表
  5. tEnv.executeSql("CREATE TABLE Orders (`user` STRING, product STRING, amount INT) WITH (...)")
  6. // 插入原始数据
  7. tEnv.executeSql("INSERT INTO Orders VALUES ('Lili', 'Apple', 1), ('Jessica', 'Banana', 2), ('Mr.White', 'Chicken', 3)").await()
  8. tEnv.executeSql("SELECT * FROM Orders").print()
  9. // +--------------------------------+--------------------------------+-------------+
  10. // | user | product | amount |
  11. // +--------------------------------+--------------------------------+-------------+
  12. // | Lili | Apple | 1 |
  13. // | Jessica | Banana | 2 |
  14. // | Mr.White | Chicken | 3 |
  15. // +--------------------------------+--------------------------------+-------------+
  16. // 3 rows in set
  17. // 全表删除数据
  18. tEnv.executeSql("TRUNCATE TABLE Orders").await()
  19. tEnv.executeSql("SELECT * FROM Orders").print()
  20. // Empty set

Python

  1. env_settings = EnvironmentSettings.in_batch_mode()
  2. table_env = TableEnvironment.create(env_settings)
  3. # 注册一个 "Orders" 表
  4. table_env.execute_sql("CREATE TABLE Orders (`user` STRING, product STRING, amount INT) WITH (...)")
  5. # 插入原始数据
  6. table_env.execute_sql("INSERT INTO Orders VALUES ('Lili', 'Apple', 1), ('Jessica', 'Banana', 2), ('Mr.White', 'Chicken', 3)").wait()
  7. table_env.execute_sql("SELECT * FROM Orders").print()
  8. # +--------------------------------+--------------------------------+-------------+
  9. # | user | product | amount |
  10. # +--------------------------------+--------------------------------+-------------+
  11. # | Lili | Apple | 1 |
  12. # | Jessica | Banana | 2 |
  13. # | Mr.White | Chicken | 3 |
  14. # +--------------------------------+--------------------------------+-------------+
  15. # 3 rows in set
  16. # 全表删除数据
  17. table_env.execute_sql("TRUNCATE TABLE Orders").wait()
  18. table_env.execute_sql("SELECT * FROM Orders").print()
  19. # Empty set

SQL CLI

  1. Flink SQL> SET 'execution.runtime-mode' = 'batch';
  2. [INFO] Session property has been set.
  3. Flink SQL> CREATE TABLE Orders (`user` STRING, product STRING, amount INT) with (...);
  4. [INFO] Execute statement succeed.
  5. Flink SQL> INSERT INTO Orders VALUES ('Lili', 'Apple', 1), ('Jessica', 'Banana', 1), ('Mr.White', 'Chicken', 3);
  6. [INFO] Submitting SQL update statement to the cluster...
  7. [INFO] SQL update statement has been successfully submitted to the cluster:
  8. Job ID: bd2c46a7b2769d5c559abd73ecde82e9
  9. Flink SQL> SELECT * FROM Orders;
  10. user product amount
  11. Lili Apple 1
  12. Jessica Banana 2
  13. Mr.White Chicken 3
  14. Flink SQL> TRUNCATE TABLE Orders;
  15. [INFO] Execute statement succeed.
  16. Flink SQL> SELECT * FROM Orders;
  17. // Empty set

语法

  1. TRUNCATE TABLE [catalog_name.][db_name.]table_name