ALTER TABLE .. ADD COLUMN IF NOT EXISTS
适用于 ✅ 开源版 ✅ 专业版 ✅ 企业版
alterTable("t").addIfNotExists("c", INTEGER)
翻译成以下特定方言的表达式
Aurora Postgres, DuckDB, Exasol, H2, MariaDB, Postgres, YugabyteDB
ALTER TABLE t ADD IF NOT EXISTS c int
BigQuery
ALTER TABLE t ADD COLUMN IF NOT EXISTS c int64
ClickHouse
ALTER TABLE t ADD COLUMN IF NOT EXISTS c Nullable(integer)
CockroachDB
ALTER TABLE t ADD IF NOT EXISTS c int4
Databricks
ALTER TABLE t ADD COLUMN IF NOT EXISTS (c int)
DB2
BEGIN
DECLARE CONTINUE HANDLER FOR SQLSTATE '42711' BEGIN END;
EXECUTE IMMEDIATE '
ALTER TABLE t ADD c integer
';
END
Firebird
EXECUTE BLOCK
AS
BEGIN
EXECUTE STATEMENT '
ALTER TABLE t ADD c integer
';
WHEN sqlcode -607 DO
BEGIN END
END
Hana
DO BEGIN
DECLARE EXIT HANDLER FOR SQL_ERROR_CODE 308 BEGIN END;
EXECUTE IMMEDIATE '
ALTER TABLE t ADD (c integer)
';
END;
Oracle
BEGIN
EXECUTE IMMEDIATE '
ALTER TABLE t ADD c number(10)
';
EXCEPTION
WHEN others THEN
IF sqlerrm LIKE 'ORA-01430%' THEN NULL;
ELSE RAISE;
END IF;
END;
SQLDataWarehouse
BEGIN TRY
EXEC sp_executesql N'
ALTER TABLE t ADD c int
';
END TRY
BEGIN CATCH
IF error_number() NOT IN (2705) 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
EXEC sp_executesql N'
ALTER TABLE t ADD c int
';
END TRY
BEGIN CATCH
IF error_number() NOT IN (2705) THROW;
END CATCH
Teradata
ALTER TABLE t ADD IF NOT EXISTS c integer
Trino
ALTER TABLE t ADD COLUMN IF NOT EXISTS c int
ASE, Access, Aurora MySQL, Derby, HSQLDB, Informix, MemSQL, MySQL, Redshift, SQLite, Snowflake, Sybase, Vertica
/* UNSUPPORTED */
使用 jOOQ 3.21 生成。早期 jOOQ 版本的支持可能有所不同。 在我们的网站上翻译您自己的 SQL
反馈
您对此页面有任何反馈吗?我们很乐意听取您的意见!