本文為您介紹遷移 MySQL 數據庫的數據至 OceanBase 數據庫 MySQL 租戶時,CREATE TABLE DDL 的同步范圍。
語法總覽
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
(create_definition,...)
[table_options]
[partition_options]
語法 | 描述 |
| |
| 詳情請參見本文《table options》模塊的內容。 |
| 詳情請參見 創建分區。 |
創建表時,支持
IF NOT EXISTS
關鍵字和LIKE
選項。示例如下:CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name { LIKE old_tbl_name | (LIKE old_tbl_name) }
創建表時,不支持創建臨時表(
TEMPORARY
關鍵字會被忽略)。說明OceanBase 數據庫 MySQL 租戶 3.2.3 版本支持創建臨時表。
創建表時,不支持創建基于查詢的表:
create table as select
,會輸出空字符串。
table options
支持指定表級別 COMMENT。
支持指定
CHARACTER SET
。其它 table option 均不支持解析,會被忽略。
table options 的詳細定義如下:
table_option: {
AUTOEXTEND_SIZE [=] value
| AUTO_INCREMENT [=] value
| AVG_ROW_LENGTH [=] value
| [DEFAULT] CHARACTER SET [=] charset_name
| CHECKSUM [=] {0 | 1}
| [DEFAULT] COLLATE [=] collation_name
| COMMENT [=] 'string'
| COMPRESSION [=] {'ZLIB' | 'LZ4' | 'NONE'}
| CONNECTION [=] 'connect_string'
| {DATA | INDEX} DIRECTORY [=] 'absolute path to directory'
| DELAY_KEY_WRITE [=] {0 | 1}
| ENCRYPTION [=] {'Y' | 'N'}
| ENGINE [=] engine_name
| ENGINE_ATTRIBUTE [=] 'string'
| INSERT_METHOD [=] { NO | FIRST | LAST }
| KEY_BLOCK_SIZE [=] value
| MAX_ROWS [=] value
| MIN_ROWS [=] value
| PACK_KEYS [=] {0 | 1 | DEFAULT}
| PASSWORD [=] 'string'
| ROW_FORMAT [=] {DEFAULT | DYNAMIC | FIXED | COMPRESSED | REDUNDANT | COMPACT}
| SECONDARY_ENGINE_ATTRIBUTE [=] 'string'
| STATS_AUTO_RECALC [=] {DEFAULT | 0 | 1}
| STATS_PERSISTENT [=] {DEFAULT | 0 | 1}
| STATS_SAMPLE_PAGES [=] value
| TABLESPACE tablespace_name [STORAGE {DISK | MEMORY}]
| UNION [=] (tbl_name[,tbl_name]...)
}
使用限制
重要
由于 OceanBase 數據庫 MySQL 租戶本身的限制,如果存在以下場景,同步的 DDL 被成功轉換后,執行到 OceanBase 數據庫 MySQL 租戶可能會報錯。
OceanBase 數據庫 MySQL 租戶支持的字符集有限。
請勿使用 latin1 等不支持的字符集。如果強行指定 OceanBase 數據庫 MySQL 租戶不支持的字符集,DDL 同步時不會將該字符集進行轉換,導致執行至目標數據庫時報錯。
文檔內容是否對您有幫助?