MySQL CHECK 制約: 無視される機能
MySQL テーブルへのカスタム CHECK 制約の追加は本質的に失敗します。制約を定義することは可能であるように見えますが、最終的には何も行われません。この動作は、バージョン 5.7 までの MySQL ストレージ エンジンで CHECK 制約がサポートされていないことが原因です。
MySQL の制限付き CHECK 制約サポート
マニュアルに記載されているように、MySQL は CHECK 制約を解析します。しかしそれらを無視します。これは、テーブル スキーマで定義された CHECK 制約がデータベースによって強制されないことを意味します。
回避策と代替案
CHECK 制約と同様のデータ整合性を強制するには、トリガーで次のことができます。雇用される。ただし、トリガーによってさらに複雑さが増し、パフォーマンス上の問題が生じる可能性があります。
アプリケーションにとって CHECK 制約が不可欠な場合は、PostgreSQL など、CHECK 制約をサポートするオープンソース RDBMS に切り替えることを検討してください。 PostgreSQL は堅牢な CHECK 制約機能を提供し、MySQL の優れた代替手段となります。
以上がMySQL CHECK 制約が無視されるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。