ホームページ > データベース > mysql チュートリアル > MySQL CHECK 制約はどのように機能しますか?また、古いバージョンと新しいバージョンでデータ検証を確実に行うにはどうすればよいですか?

MySQL CHECK 制約はどのように機能しますか?また、古いバージョンと新しいバージョンでデータ検証を確実に行うにはどうすればよいですか?

Barbara Streisand
リリース: 2025-01-10 10:32:42
オリジナル
288 人が閲覧しました

How Do MySQL CHECK Constraints Work, and How Can I Ensure Data Validation in Older and Newer Versions?

MySQL の CHECK 制約

MySQL テーブルに CHECK 制約を追加しようとすると、制約に違反するデータを挿入すると予期しない動作が発生する可能性があります。この記事では、MySQL の CHECK 制約の微妙な点を詳しく掘り下げ、検証を強制するためのソリューションを提供します。

MySQL の以前のバージョン (8.0.15 まで) では、CHECK 制約は定義されていましたが、強制されませんでした。 MySQL リファレンス マニュアルに記載されているように、「CHECK 句はすべてのストレージ エンジンによって解析されますが、無視されます。」

MySQL 8.0.15 以前のソリューション

ネイティブの CHECK 制約がサポートされていない場合にデータ検証を強制するには、トリガーを作成できます:

<code class="language-sql">DELIMITER //

CREATE TRIGGER trig_sd_check BEFORE INSERT ON Customer
FOR EACH ROW
BEGIN
  IF NEW.SD < 0 THEN
    SET NEW.SD = 0;
  END IF;
END //

DELIMITER ;</code>
ログイン後にコピー

このトリガーはあらゆる INSERT ステートメントをインターセプトし、SD 列の値が 0 未満の場合は 0 に変更され、制約が確実に維持されます。

MySQL 8.0.16 以降の CHECK 制約

MySQL 8.0.16 では、CHECK 制約の完全なサポートが導入されています。 8.0.16 以降で CHECK 制約を定義するには、次の構文を使用します:

<code class="language-sql">CREATE TABLE Customer (
  SD integer CHECK (SD > 0),
  Last_Name varchar (30),
  First_Name varchar(30)
);</code>
ログイン後にコピー

MySQL は制約を強制し、制約に違反するデータの挿入を防止します。

以上がMySQL CHECK 制約はどのように機能しますか?また、古いバージョンと新しいバージョンでデータ検証を確実に行うにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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