MySQL での and or クエリの優先度分析

MySQL での and or クエリの優先度分析

これは見落とされがちな問題かもしれません。まず、次の点を明確にする必要があります。
MySQL では、AND は OR よりも実行優先度が高くなります。つまり、括弧 () の制限がなければ、AND ステートメントが常に最初に実行され、次に OR ステートメントが実行されます。
例えば:

条件 1 かつ条件 2 または条件 3 のテーブルから * を選択
select * from table where (条件 1 AND 条件 2) OR 条件 3 と同等

条件 1 かつ条件 2 または条件 3 かつ条件 4 のテーブルから * を選択
select * from table where (条件 1 AND 条件 2) OR (条件 3 AND 条件 4) と同等

より深く理解するために、いくつかの例を見てみましょう。

テストテーブルデータ:

名前を設定します utf8mb4;
FOREIGN_KEY_CHECKS = 0 を設定します。

-- ----------------------------
-- 本の表構造
-- ----------------------------
`book` が存在する場合はテーブルを削除します。
テーブル「book」を作成します(
 `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT,
 `name` varchar(25) 文字セット utf8mb4 COLLATE utf8mb4_0900_ai_ci デフォルト NULL,
 `author` varchar(25) 文字セット utf8mb4 COLLATE utf8mb4_0900_ai_ci デフォルト NULL,
 `price` 小数点(10, 2) デフォルト NULL,
 BTREE を使用した主キー (`id`)
) エンジン = InnoDB 文字セット = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- 書籍の記録
-- ----------------------------
`book` に VALUES (1, 'PHP', 'mate', 21.00) を挿入します。
`book` に VALUES (2, 'JAVA', 'kaven', 23.00) を挿入します。
`book` に VALUES (3, 'JAVA Advanced', 'loose', 45.00) を挿入します。
`book` に VALUES (4, 'GO', 'jim', 46.00) を挿入します。
`book` に VALUES (5, 'GO Design', 'json', 76.00) を挿入します。
INSERT INTO `book` VALUES (6, 'PHP Advanced Programming', 'bate', 67.00);
`book` に 7、'Python'、'jim'、66.00 を挿入します。
`book` に VALUES (8, 'Python Design', 'mali', 54.00) を挿入します。
`book` に VALUES (9, 'GO Programming', 'kaven', 86.00) を挿入します。
`book` に値 (11, 'Python3', 'jim', 55.00) を挿入します。

FOREIGN_KEY_CHECKS = 1 を設定します。

クエリ方法 1:

SELECT * FROM book WHERE author='jim' OR author='json' AND name='PHP';

上記のクエリは次のクエリと同等です。

SELECT * FROM book WHERE author='jim' OR (author='json' AND name='PHP');

すると、上記のクエリ結果が簡単に理解できるようになります。

クエリ方法 2:

SELECT * FROM book WHERE name='PHP' AND author='jim' OR author='json';

上記のクエリは次のクエリと同等です。

SELECT * FROM book WHERE (name='PHP' AND author='jim') OR author='json';

クエリ方法3:

SELECT * FROM book WHERE name='GO' AND (author='jim' OR author='json');

これは理解しやすいですね。 and またはの優先順位を理解します。これらのクエリはそれほど「理解するのが難しい」ものではありません。

これで、MySQL の and or クエリの優先度分析に関するこの記事は終了です。MySQL および or クエリに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • And キーワードを使用した MySQL の複数条件クエリ ステートメント
  • MySQL 条件付きクエリと使用法および優先順位の例の分析
  • MySQL 左結合マルチテーブルクエリの条件記述例
  • PHPがMySQLクエリの結果を配列に変換し、それを連結する例
  • MySQLクエリ条件におけるonとwhereの配置の違いの分析
  • MySQL接続クエリにおけるととwhereの違いの簡単な分析

<<:  CSS3 FlexBox の伸縮自在なレイアウトを 10 分で理解する

>>:  フォーム要素とプロンプトテキストが揃っていない問題

推薦する

Javascript を使用して、スライドバー効果のあるスライドナビゲーション プラグインを開発します。

目次1. はじめに2. 使用方法3. 開発プロセス1. モデル例2. イベントとアニメーション4. ...

Dockerの急速な拡張の高度な方法

1. コマンド方式作成された Swarm クラスターで nginx サービスを実行し、--repli...

MySQLの通常インデックスとユニークインデックスの違いの詳しい説明

目次1 概念上の区別2 事例紹介3 クエリパフォーマンス4 アップデートのパフォーマンス4.1 記憶...

MySQL の自己結合重複排除に関する注意事項

機能シナリオを簡単に説明しましょう。データ行フィールドは次のとおりです。名前開始日時タイプこの表では...

VUE ユニアプリカスタムコンポーネントについての簡単な説明

1. 親コンポーネントはpropsを通じて子コンポーネントにデータを渡すことができる2. 子コンポー...

デザイナーはコーディングを学ぶ必要がありますか?

多くの場合、 Web デザインが完成した後でデザイナーの無知が露呈し、批判されることがあります。彼ら...

Vueプロジェクトがグラフィック検証コードを実装

この記事の例では、グラフィック検証コードを実装するためのVueプロジェクトの具体的なコードを参考まで...

HTML CSS に基づく検索アイコン付き検索ボックス機能を実装する

序文フロントエンドで非常に便利な、小さなアイコン付きの検索ボックスを作成する方法をご紹介します。エフ...

Linux のファイル システム タイプの表示方法の例

Linux でパーティションのファイル システム タイプを確認する方法。パーティションのファイル シ...

JavaScript をスリープまたは待機させる方法

目次概要setTimeout() の確認スリープ関数の書き方シンプルな選択ループで実行されますか?要...

jQuery エディタ プラグイン tinyMCE の使い方

簡略化されたファイル サイズを変更し、サンプルをダウンロードします。ファイルをローカル コンピュータ...

Linux コマンドラインのクイックヒント: ファイルの検索方法

私たちのコンピューターには、ディレクトリ、写真、ソース コードなどのファイルが保存されています。たく...

dockercompose を使用して springboot-mysql-nginx アプリケーションをビルドする

前回の記事では、Docker を使用して、コンパイルされた jar パッケージをイメージに組み込む ...