可用版本: Dev (3.21) | 最新 (3.20) | 3.19 | 3.18 | 3.17 | 3.16 | 3.15

IF EXISTS

适用于 ✅ 开源版   ✅ 专业版   ✅ 企业版

为了幂等地执行 DDL 脚本,jOOQ 支持有用的 IF EXISTS 子句,并在可能的情况下使用匿名过程块来模拟。

// Drop a trigger
create.dropTriggerIfExists("trg").execute();

方言支持

此示例使用 jOOQ

dropTriggerIfExists("type")

翻译成以下特定方言的表达式

Aurora Postgres, Postgres

DO $$
BEGIN
  DROP TRIGGER IF EXISTS type;
  DROP FUNCTION IF EXISTS type_function;
END;
$$

DB2

BEGIN
  DECLARE CONTINUE HANDLER FOR SQLSTATE '42704' BEGIN END;
  EXECUTE IMMEDIATE '
    DROP TRIGGER type
  ';
END

Firebird

EXECUTE BLOCK
AS
BEGIN
  EXECUTE STATEMENT '
    DROP TRIGGER type
  ';
  WHEN sqlcode -607 DO
    BEGIN END
END

MariaDB、MySQL、Oracle、SQLServer

DROP TRIGGER IF EXISTS type

ASE、Access、Aurora MySQL、BigQuery、ClickHouse、CockroachDB、Databricks、Derby、DuckDB、Exasol、H2、HSQLDB、Hana、Informix、MemSQL、Redshift、SQLDataWarehouse、SQLite、Snowflake、Sybase、Teradata、Trino、Vertica、YugabyteDB

/* UNSUPPORTED */
使用 jOOQ 3.21 生成。早期 jOOQ 版本的支持可能有所不同。 在我们的网站上翻译您自己的 SQL

反馈

您对此页面有任何反馈吗? 我们很乐意听取您的意见!

The jOOQ Logo