ホームページ > データベース > mysql チュートリアル > Hibernate で生成された DDL で「type=MyISAM」構文エラーが発生するのはなぜですか?

Hibernate で生成された DDL で「type=MyISAM」構文エラーが発生するのはなぜですか?

Mary-Kate Olsen
リリース: 2024-11-15 07:16:02
オリジナル
378 人が閲覧しました

Why am I getting the

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:

  • org.hibernate.dialect.MariaDBDialect
  • org.hibernate.dialect.MariaDB53Dialect
  • org.hibernate.dialect.MariaDB106Dialect (または上位)

MySQL の場合、または MariaDB 方言が利用できない場合は、次のことを検討してください。使用:

  • org.hibernate.dialect.MySQL5Dialect
  • org.hibernate.dialect.MySQL55Dialect
  • org.hibernate.dialect.MySQL57Dialect
  • org.hibernate.dialect.MySQL8Dialect
  • バリアントこれらの方言 (例: org.hibernate.dialect.MySQL57InnoDBDialect)

Hibernate 6 の方言

Hibernate 6 では、ユーザーは MySQLDialect の使用に戻す必要があります。 MariaDBDialect は、これらの方言が実際の言語に基づいて設定されるためです。接続バージョン。

以上がHibernate で生成された DDL で「type=MyISAM」構文エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート