IF EXISTS
适用于 ✅ 开源版 ✅ 专业版 ✅ 企业版
为了 DDL 脚本的幂等执行,jOOQ 支持有用的 IF EXISTS 子句,并尽可能使用匿名过程块模拟它。
// Drop a view
create.dropViewIfExists("view").execute();
方言支持
此示例使用 jOOQ
dropViewIfExists("v")
翻译成以下特定方言的表达式
访问
DROP VIEW v
Aurora MySQL, Aurora Postgres, BigQuery, ClickHouse, CockroachDB, Databricks, DuckDB, Exasol, H2, HSQLDB, Informix, MariaDB, MemSQL, MySQL, Oracle, Postgres, Redshift, SQLite, Sybase, Trino, Vertica, YugabyteDB
DROP VIEW IF EXISTS v
DB2
BEGIN
DECLARE CONTINUE HANDLER FOR SQLSTATE '42704' BEGIN END;
EXECUTE IMMEDIATE '
DROP VIEW v
';
END
Firebird
EXECUTE BLOCK
AS
BEGIN
EXECUTE STATEMENT '
DROP VIEW v
';
WHEN sqlcode -607 DO
BEGIN END
END
Hana
DO BEGIN
DECLARE EXIT HANDLER FOR SQL_ERROR_CODE 321 BEGIN END;
EXECUTE IMMEDIATE '
DROP VIEW v
';
END;
SQLDataWarehouse
BEGIN TRY
DROP VIEW v
END TRY
BEGIN CATCH
IF error_number() NOT IN (3701) BEGIN
DECLARE @ErrorMessage NVARCHAR(4000) = ERROR_MESSAGE();
DECLARE @ErrorSeverity INT = ERROR_SEVERITY();
DECLARE @ErrorState INT = ERROR_STATE();
RAISERROR (@ErrorMessage, @ErrorSeverity, @ErrorState);
END;
END CATCH
SQLServer
BEGIN TRY DROP VIEW v END TRY BEGIN CATCH IF error_number() NOT IN (3701) THROW; END CATCH
ASE, Derby, Snowflake, Teradata
/* UNSUPPORTED */
使用 jOOQ 3.21 生成。早期 jOOQ 版本的支持可能有所不同。 在我们的网站上翻译您自己的 SQL
反馈
您对此页面有任何反馈吗? 我们很乐意听取您的意见!