MySQL 8.0 の新機能 - チェック制約の紹介

MySQL 8.0 の新機能 - チェック制約の紹介

序文

MySQL 8.0 では、チェック制約という非常に便利な新機能が導入されました。これにより、不正または不合理なデータ書き込みに対する制御が向上します。詳しく見てみましょう。

チェック制約

作成、削除、表示

(1)テーブル作成時にチェック制約を作成できます。

mysql> テーブル t1 を作成します
 -> (
 -> チェック (c1 <> c2)、
 -> c1 INT チェック (c1 > 10)、
 -> c2 INT 制約 c2_positive チェック (c2 > 0)、
 -> c3 INT チェック (c3 < 100)、
 -> 制約 c1_nonzero チェック (c1 <> 0)、
 -> チェック (c1 > c3)
 -> );
クエリは正常、影響を受けた行は 0 行 (0.03 秒)

(2)次の文を使用してチェック制約を追加することもできます。

mysql> ALTER TABLE t1 制約 c3_nonzero CHECK ((c3<>0)) を追加します。
クエリは正常、影響を受けた行は 0 行 (0.16 秒)
レコード: 0 重複: 0 警告: 0

(3)次の文を使ってチェック制約を削除することができます。

mysql> ALTER TABLE t1 DROP CONSTRAINT c3_nonzero;
クエリは正常、影響を受けた行は 0 行 (0.02 秒)
レコード: 0 重複: 0 警告: 0

(4)テーブル構造をクエリすることでチェック制約を表示できます。

mysql> SHOW CREATE TABLE t1_G
************************** 1. 行 ****************************
 表: t1
テーブルの作成: CREATE TABLE `t1` (
 `c1` int デフォルト NULL,
 `c2` int デフォルト NULL,
 `c3` int デフォルト NULL,
 制約 `c1_nonzero` チェック ((`c1` <> 0))、
 制約 `c2_positive` チェック ((`c2` > 0))、
 制約 `t1_chk_1` チェック ((`c1` <> `c2`)),
 制約 `t1_chk_2` チェック ((`c1` > 10))、
 制約 `t1_chk_3` チェック ((`c3` < 100))、
 制約 `t1_chk_4` チェック ((`c1` > `c3`))
) エンジン=InnoDB デフォルト文字セット=utf8mb4 照合=utf8mb4_0900_ai_ci
セット内の 1 行 (0.00 秒)

(5) 次の 2 つのビューを通じて表示することもできます。table_constraints はテーブルに存在する制約を照会し、check_constraints はチェック制約の特定の定義を照会します。

mysql> SELECT * FROM information_schema.table_constraints WHERE table_name='t1';
+--------------------+-------------------+-----------------+--------------+------------+-----------------+----------+
| CONSTRAINT_CATALOG | CONSTRAINT_SCHEMA | CONSTRAINT_NAME | TABLE_SCHEMA | TABLE_NAME | CONSTRAINT_TYPE | ENFORCED |
+--------------------+-------------------+-----------------+--------------+------------+-----------------+----------+
| def | テスト | c1_nonzero | テスト | t1 | チェック | はい |
| def | テスト | c2_positive | テスト | t1 | チェック | はい |
| def | テスト | t1_chk_1 | テスト | t1 | チェック | はい |
| def | テスト | t1_chk_2 | テスト | t1 | チェック | はい |
| def | テスト | t1_chk_3 | テスト | t1 | チェック | はい |
| def | テスト | t1_chk_4 | テスト | t1 | チェック | はい |
+--------------------+-------------------+-----------------+--------------+------------+-----------------+----------+
セット内の 6 行 (0.00 秒)

mysql> SELECT * FROM information_schema.check_constraints WHERE constraint_name='c1_nonzero';
+--------------------+-------------------+-----------------+--------------+
| CONSTRAINT_CATALOG | CONSTRAINT_SCHEMA | CONSTRAINT_NAME | CHECK_CLAUSE |
+--------------------+-------------------+-----------------+--------------+
| 定義 | テスト | c1_nonzero | (`c1` <> 0) |
+--------------------+-------------------+-----------------+--------------+
セット内の 1 行 (0.00 秒)

(6)チェック制約を満たさないデータを挿入すると、エラーが直接報告されます。

mysql> t1 に値 (0,0,0) を挿入します。
エラー 3819 (HY000): チェック制約 'c1_nonzero' に違反しています。

制限

(1)自動増分列と他のテーブルの列はチェック制約をサポートしていない

(2)CONNECTION_ID()、CURRENT_USER()、NOW()などの不確実な関数はチェック制約をサポートしていません。

(3)ユーザー定義関数はチェック制約をサポートしていない

(4)ストアドプロシージャはチェック制約をサポートしていない

(5)変数はチェック制約をサポートしていない

(6)サブクエリはチェック制約をサポートしていない

要約する

チェック制約は、さまざまなデータ検証シナリオを実現できる非常に優れた機能です。ぜひお試しください。

以上がMySQL 8.0の新機能であるチェック制約の簡単な紹介です。MySQL 8.0の新機能であるチェック制約の詳細については、123WORDPRESS.COMの他の関連記事にご注目ください。

以下もご興味があるかもしれません:
  • MySQL の null 制約のケースの説明
  • MySQL 外部キー制約 (FOREIGN KEY) ケースの説明
  • MySQL 外部キー制約とテーブル関係の概要
  • MySQL 整合性制約の定義と例のチュートリアル
  • MySQL での外部キーの作成、制約、削除
  • MySQL のインデックスと制約の例文
  • MySQL 外部キー制約の例の説明
  • MySQL 外部キー制約の詳細な説明
  • MySQL 整合性制約の例の詳細な説明
  • MySQL 制約の超詳細な説明

<<:  docker run -v はデータボリュームを異常にマウントし、コンテナのステータスは常に再起動になります。

>>:  HTMLリンクタグのrel属性

推薦する

完璧なアロエベラジェルを選ぶには?完璧なアロエベラジェルの本物と偽物の見分け方

最新のパーフェクト アロエ ベラ ジェルのパッケージ ボックスには、赤いフォントで完璧な英語の文字が...

Windows で mysql5.7.21 をインストールするための詳細なチュートリアル

この記事では、参考までにMySQL 5.7.21のインストールチュートリアルを紹介します。具体的な内...

IDEA を MYSQL データベースに接続するための構成時に失敗する問題の解決策

この記事では、主に、IDEA を MYSQL データベースに接続するための構成時に失敗する問題の解決...

シンプルなドラッグ効果を実現するJavaScript

この記事では、簡単なドラッグ効果を実現するためのJavaScriptの具体的なコードを参考までに紹介...

JavaScriptの動作メカニズムの詳細な説明とイベントループについての簡単な説明

目次1. JavaScript がシングルスレッドなのはなぜですか? 2. タスクキュー3. イベン...

Vue スキャフォールディングでのレンダリングを理解する

Vue スキャフォールディングでは、エントリ ファイル main.js の新しい Vue コードに、...

「@INC で ExtUtils/MakeMaker.pm が見つかりません」というエラーを解決する

mha4mysql をインストールする場合の手順は、おおよそ次のようになります: unzip、per...

バージョン管理ツール Rational ClearCase の紹介

Rational ClearCase は、コードやその他のソフトウェア開発資産のバージョン管理を実...

CentOS 7にMySQLをインストールする詳細な手順

CentOS7では、MySQLをインストールすると、MariaDBもデフォルトでインストールされます...

Reactホームページの読み込みが遅い問題のパフォーマンス最適化事例の詳細な説明

しばらくReactを勉強した後、実践してみたいと思います。そこで、個人のブログのウェブサイトを再構築...

Vmvare 仮想マシンを使用して Ubuntu のルート ディレクトリをパーティション分割する方法の紹介

目次序文根拠手順1. CDから仮想マシンを起動する2. GPartedツールを使用してパーティション...

Linux のごみ箱メカニズムの実装プロセスと使用方法の詳細な説明

序文: Linux システムでの rm は元に戻せません。コマンドの設計自体に問題はありません。問題...

Vue の高度な構築プロパティの詳細な説明

目次1. ディレクティブカスタムディレクティブ2. ミックスイン3. 継承を拡張する4. 提供して注...

Node+Express テストサーバーのパフォーマンス

目次1 テスト環境1.1 サーバーハードウェア1.1.1 t2.マイクロ1.1.2 c5.large...

div要素に丸い境界線を追加する方法

以下のように表示されます。 CSSコードコンテンツをクリップボードにコピー分割{境界線: 2px 固...