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

MySQLサブクエリを使用してデータをフィルタリングするにはどうすればよいですか?


INキーワードを使用すると、サブクエリを使用してデータをフィルタリングできます。これは、IN演算子で値のリストを使用して、別のクエリの結果に基づいてクエリをフィルタリングするのと同じように、クエリの結果を使用できるためです。サブクエリは、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)

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

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

  1. MySQLでIDが最も高い行を選択するにはどうすればよいですか?

    LIMIT OFFSET を使用したORDERBYを使用して、MySQLでIDが最も高い行を選択できます。 構文は次のとおりです- select *from yourTableName order by yourColumnName desc limit 1 offset 0; 上記の構文を理解するために、テーブルを作成しましょう。テーブルを作成するためのクエリは次のとおりです- mysql> create table HighestIdOrderBy    −> (    −> EmployeeId int

  2. MySQLテーブルの最大IDに関連付けられたデータを取得するにはどうすればよいですか?

    最初にDESCで注文し、次に最大IDに関連付けられた値をフェッチします- select *from yourTableName order by yourColumnName DESC LIMIT 1,1; まずテーブルを作成しましょう- mysql> create table DemoTable    -> (    -> Alldata int    -> ); Query OK, 0 rows affected (0.63 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します