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
反馈
您对此页面有任何反馈吗? 我们很乐意听取您的意见!