Hibernate で生成された DDL の無効な構文エラー "type=MyISAM"
Java コードでは、次の構文エラーが発生する可能性があります。
Caused by :`com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException`: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB' server version for the right syntax to use near 'type = `MyISAM`' at line 1
このエラーは、Hibernate がテーブルを生成するときに発生しますフラグメント「type = MyISAM」を含む作成クエリ。ただし、この構文は MySQL 4.0 で非推奨となり、5.5 で削除されました。
Dialect 構成
問題は org.hibernate.dialect.MySQLDialect 方言の使用に起因します。 、これは MySQL 4.x 以前用です。 MariaDB の場合は、MariaDB のバージョンに応じて次の方言のいずれかを使用することをお勧めします。 Hibernate:
MySQL の場合、または MariaDB 方言が利用できない場合は、次のことを検討してください。使用:
Hibernate 6 の方言
Hibernate 6 では、ユーザーは MySQLDialect の使用に戻す必要があります。 MariaDBDialect は、これらの方言が実際の言語に基づいて設定されるためです。接続バージョン。
以上がHibernate で生成された DDL で「type=MyISAM」構文エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。