MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

MySQLサブクエリでの「ALL」、「ANY」、「SOME」、「IN」演算子の使用は何ですか?


「ALL」、「ANY」、「SOME」、「IN」 演算子は、値をサブクエリによって返されるすべての値と比較します。これらの演算子はすべて、比較演算子に従う必要があります。 MySQLサブクエリでこれらの演算子を使用する構文は次のとおりです-

「ALL」を使用するための構文
Operand comparison_operator ALL (subquery)
「ANY」を使用するための構文
Operand comparison_operator ANY (subquery)
「SOME」を使用するための構文
Operand comparison_operator SOME (subquery)
「IN」の使用構文
Operand comparison_operator IN (subquery)

次の表のデータを使用して、「ALL」、「ANY」、「SOME」、「IN」の使用法を説明しています サブクエリを持つ演算子。

mysql> Select * from Customers;
+-------------+----------+
| Customer_Id | Name     |
+-------------+----------+
|           1 | Rahul    |
|           2 | Yashpal  |
|           3 | Gaurav   |
|           4 | Virender |
+-------------+----------+
4 rows in set (0.00 sec)

mysql> Select * from Reservations;
+------+-------------+------------+
| ID   | Customer_id | Day        |
+------+-------------+------------+
|    1 |           1 | 2017-12-30 |
|    2 |           2 | 2017-12-28 |
|    3 |           2 | 2017-12-29 |
|    4 |           1 | 2017-12-25 |
|    5 |           3 | 2017-12-26 |
+------+-------------+------------+
5 rows in set (0.00 sec)

以下のクエリは、サブクエリで「ALL」演算子を使用し、サブクエリによって返されたすべての値を比較した後に結果を返します。

mysql> SELECT customer_id from Customers WHERE customer_id <> ALL(Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           4 |
+-------------+
1 row in set (0.00 sec)

以下のクエリは、サブクエリで「ANY」演算子を使用し、サブクエリによって返されたすべての値を比較した後に結果を返します。

mysql> SELECT customer_id from customers WHERE customer_id = ANY(Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           1 |
|           2 |
|           3 |
+-------------+
3 rows in set (0.00 sec)

以下のクエリは、サブクエリで「SOME」演算子を使用し、サブクエリによって返されたすべての値を比較した後に結果を返します。

mysql> SELECT customer_id from customers WHERE customer_id = Some(Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           1 |
|           2 |
|           3 |
+-------------+
3 rows in set (0.00 sec)

以下のクエリは、サブクエリで「IN」演算子を使用し、サブクエリによって返されたすべての値を比較した後に結果を返します。

mysql> SELECT customer_id from customers WHERE customer_id IN (Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           1 |
|           2 |
|           3 |
+-------------+
3 rows in set (0.00 sec)

  1. MySQL IGNORE INSERTステートメントの用途は何ですか?

    基本的に、IGNORE INSERTステートメントは、MySQLテーブルへの重複データの挿入を防ぐために使用されます。 INSERTコマンドではなくINSERTIGNOREコマンドを使用する場合、レコードが既存のレコードを複製しない場合、MySQLは通常どおりにそれを挿入しますが、レコードが複製する場合、IGNOREキーワードはMySQLに生成せずにサイレントに破棄するように指示しますエラー。その構文は次のとおりです- 構文 INSERT INGORE INTO table_name(…) ここで、table_nameは、値を挿入するテーブルの名前です。 例 次の例ではエラーが

  2. MySQLサブクエリを使用して最大年齢値を持つすべてのユーザーを選択しますか?

    まずテーブルを作成しましょう- mysql> create table DemoTable (    Name varchar(100),    Age int ); Query OK, 0 rows affected (0.46 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable values('Chris',23); Query OK, 1 row affected (0.20 sec) mysql> insert into Dem