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

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

推薦する

MySQL SQL文の特殊処理文のまとめ(必読)

1.テーブル全体を更新します。データ行の列の値が空の場合は、別の列フィールドの値と同じにします。 ...

CSS3 の transition、transform、translate の違いと機能の簡単な分析

変換して翻訳するTransform は、変換と変形を意味します。他の幅属性や高さ属性と同様に、CSS...

html の img src="" で js 関数または js 変数を呼び出して、画像パスを動的に指定します。

この問題に関して、オンライン リソースをたくさん見つけました。ここにいくつかの方法を示します。コード...

MySql 自動切り捨て例の詳細な説明

MySql 自動切り捨て例の詳細な説明友人が質問しました。プロジェクト内で挿入または更新ステートメン...

CSS スキル コレクション - 古典の中の古典

リンク上の点線のボックスを削除しますコードをコピーコードは次のとおりです。 a:アクティブ、a:フォ...

Select はダブルクリック dbclick イベントをサポートしていません

XML/HTML コードコンテンツをクリップボードにコピー< div クラス= "c...

Node.js mysqlクライアントが認証プロトコルをサポートしていない問題を解決する

序文mysql モジュール (プロジェクト アドレスは https://github.com/mys...

Vueフィルターとカスタム命令の使用

目次フィルター01.とは02. やり方(1)フィルターを定義する(2)使用方法(3)フィルタパラメー...

MySQL で not in を使用して null 値を含める問題を解決する

知らせ! ! ! uid が (a,b,c,null) に含まれないユーザーから * を選択します。...

リクエスト数を制限するために Ajax 同時リクエストを実装するために js を使用するサンプル コード

問題の説明: 非同期リクエストの数が不確定な場合、数百の http リクエストが瞬時に発生したときに...

CSS導入方法4つのまとめ(共有)

1. インライン参照:ラベルに直接使用されるが、メンテナンスコストが高い スタイル='フォ...

MySQLリモート接続失敗の解決策

以前、MySQLがローカルでは接続できるのにリモートでは接続できないという問題に遭遇したことがありま...

トップに戻るボタンの例の JavaScript 実装

この記事では、トップに戻るボタンを実装するためのJavaScriptの具体的なコードを参考までに紹介...

ドラッグアンドドロップでVueユーザーインターフェースを生成する方法

目次序文1. 技術原理1.1 レイアウト1.2 コンポーネント1.3 ステータス1.4 イベント1....