0


0

私はそれをインストールした後私はちょうどdrupalによって作成されたMySqlデータベースを見ていました。 すべてのテーブルはMyISAMにあります。

drupalのような複雑なソフトウェアでは、参照整合性を強化するために外部キー、したがってInnoDBテーブルを使用するほうが理にかなっていませんか

外部キーがなければ、すべての制約チェックはPHP側で行われます。

1 Answer


3


MySQLはさまざまなデータベースエンジンを提供しています。理由はそれぞれ異なります。 InnoDBは参照の整合性とトランザクションの安全性を提供する優れたエンジンですが、Webサイトの使用例には最適化されていません。

MyISAMは、ほとんどのヒットがデータベースへの読み取りアクセスのみを必要とするWebサイトに対して最高のパフォーマンスを提供します。 このような場合、参照の整合性は、整合性が損なわれた場合に成功しないようにデータの挿入と削除を書き込むことによって維持できることがほとんどです。 例えば、書く代わりに

mytableのWHERE id = 5から削除します

あなたは書ける

mytableからmytableを削除するLEFT JOIN linkedtable on mytable.id = linkedtable.ref WHERE id = 5かつlinkedtable.refがNULLです

が外部参照でない場合にのみ、行を削除することに成功します。