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 分で理解する

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

推薦する

外部ネットワークアクセスを許可するためのMysql5.6の設定手順の詳細を共有する

最近、MySQL 5.6 を導入しましたが、デフォルトでは MySQL はローカル サービスのみを許...

js キャンバスはスライダー検証を実現します

この記事の例では、スライダー検証を実装するためのjsキャンバスの具体的なコードを参考までに共有してい...

Bootstrap 3.0 学習ノート グリッドシステム事例

序文前回の記事では、主にグリッドシステムの基本原理を学び、簡単なケースを通してその原理を実践しました...

Navicat の MySQL へのリモート接続が遅い理由の詳細な説明

最終的な解決策は最後の写真にありますリモート データベース ( Linux システム) に接続したと...

ubuntu16.04でNFSサービスを構築する方法

NFS の紹介NFS (ネットワーク ファイル システム) は、FreeBSD でサポートされている...

MySQL で最大接続数を正しく変更する 3 つの方法

MySQL データベースをインストールすると、デフォルトの MySQL データベースの最大接続数が ...

docker ストレージを使用して Exit を実行すると、サーバーへのファイルのアップロードが失敗する問題と解決策

1. 問題の説明Docker コンテナにインストールされているストレージが終了状態になっているため、...

Windows 10 システムで nginx ファイル サーバーを構成するためのグラフィック チュートリアル

Nginx の公式 Web サイトから Windows バージョンの Nginx をダウンロードしま...

React HTML で react を使用する 2 つの方法

基本的な使い方 <!DOCTYPE html> <html lang="...

MySQLで最新のトランザクションIDを照会する方法

前に書いた内容: ビジネス ロジックの判断を行うために、最新のトランザクション ID を表示する必要...

SpringBoot でマイクロサービスを構築するために Docker を使用した実際の記録を分析する

それは何ですか? Spring Boot は、Spring オープンソース組織のサブプロジェクトであ...

js でパズルゲームを実装する

この記事では、パズルゲームを実装するためのjsの具体的なコードを参考までに共有します。具体的な内容は...

JavaScript WeakMap の使い方の詳しい説明

WeakMap オブジェクトは、キーが弱参照であるキー/値のペアのコレクションです。キーはオブジェク...

数十行のjsを使用してクールなキャンバスインタラクティブ効果を実現する方法を教えます

目次1. 円を描く2. マウスで動かした円3. マウスでドラッグした粒子4. カラーグラデーション粒...