Hibernate 生成的 DDL 中出现无效语法错误“type= MyISAM”
使用 MySQL 作为底层数据库在 Hibernate 中创建表时,您可能会遇到一条错误,指出“您的 SQL 语法有错误;请检查与您的 MariaDB 服务器版本相对应的手册,以获取在附近使用的正确语法” 'type = MyISAM' at line 1."
原因:
此错误通常是因为用于生成表定义的 MySQLDialect 方言不适合该版本而发生您正在使用的 MySQL 或 MariaDB。在 Hibernate 5.x 及更早版本中,MySQLDialect 是为 MySQL 4.x 或更早版本设计的,其中包含“type = MyISAM”语法。但是,在 MySQL 5.5 及更高版本中,此语法已被弃用,需要替换为“ENGINE = MyISAM”。
解决方案:
要解决此错误,您应该将 Hibernate 使用的方言更新为与您的数据库版本兼容的方言:
配置:
在提供的配置文件中,您使用的是 org.hibernate.dialect.MySQLDialect,它不适合 MySQL 5.5或稍后。您需要更新配置才能使用上述兼容方言之一。例如:
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
Hibernate 6 的注意事项:
在 Hibernate 6 中,方言将根据实际连接的版本自行配置。因此,如果您使用 Hibernate 6,您应该恢复使用 MySQLDialect 或 MariaDBDialect。
以上是为什么 Hibernate 在 MySQL/MariaDB 中生成无效的'type=MyISAM”语法以及如何修复它?的详细内容。更多信息请关注PHP中文网其他相关文章!