报错本质是目标数据库禁用或不支持声明的存储引擎。MySQL需检查SHOW ENGINES;PostgreSQL不支持ENGINE等子句;SQLite需确认扩展模块是否启用;跨库迁移须校验引擎语义一致性。
这类报错本质不是 navicat 的问题,而是目标 mysql 实例禁用了 innodb(或其它声明的引擎),常见于精简版、docker 镜像、或手动编译时关闭了引擎支持。navicat 在解析 create table 语句时发现 engine=innodb 却无法加载该引擎,就会中止导入。
验证方式:连上目标库执行 SHOW ENGINES;,检查 InnoDB 行的 SUPPORT 列是否为 NO 或 DISABLED。
NO:说明编译时未启用,需重装支持 InnoDB 的 MySQL 二进制包DISABLED:检查配置文件中是否含 skip-innodb 或 disabled_storage_engines = "innodb",删掉并重启 mysqldENGINE=InnoDB → ENGINE=MyISAM(注意 MyISAM 不支持事务和外键)USING INDEX 报错Navicat 从其他数据库(如 MySQL)迁移或导出的 SQL,常带 MySQL 风格的存储参数,例如 USING INDEX TABLESPACE pg_default 或 ROW_FORMAT=DYNAMIC。PostgreSQL 不识别这些,会直接报语法错误。
关键点:PostgreSQL 没有 “存储引擎” 概念,只有访问方法(ACCESS METHOD)和表空间,且不接受 MySQL 的 ENGINE/ROW_FORMAT 等子句。
ENGINE=...、ROW_FORMAT=...、KEY_BLOCK_SIZE=...、STATS_... 类参数USING INDEX 在 PostgreSQL 中仅用于 CREATE INDEX,不能出现在 CREATE TABLE 里——删掉整段SQLite 本身没有传统意义的存储引擎,但扩展模块(如 fts5、json1、rtree)被误当作引擎引用时,Navicat 会尝试执行含 USING fts5 的建表语句,而目标 SQLite 库未启用对应模块。
典型场景:从支持 FTS5 的 SQLite 导出,再导入到旧版或裁剪版 SQLite(如某些嵌入式环境)。
PRAGMA compile_options; 查看是否含 ENABLE_FTS5
USING fts4(兼容性更好),或直接删掉 USING ... 子句改用普通列 + 全文检索逻辑即使没报错,硬编码 ENGINE 也可能导致行为偏差。例如 MySQL 中 ENGINE=InnoDB 默认开启外键检查,而 ENGINE=MyISAM 完全忽略 FOREIGN KEY 定义 —— Navicat 不会警告,但数据一致性已丢失。
更隐蔽的是 MariaDB 的 Aria 引擎与 MySQL 的 InnoDB 在崩溃恢复、锁粒度上的差异,可能让迁移后查询变慢或死锁。
SELECT @@default_storage_engine; 确认默认值