ホームページ >データベース >mysql チュートリアル >MySQL の GROUP BY 句はどのように DISTINCT 句のように動作しますか?

MySQL の GROUP BY 句はどのように DISTINCT 句のように動作しますか?

WBOY
WBOY転載
2023-09-08 13:09:021289ブラウズ

MySQL GROUP BY 子句如何表现得像 DISTINCT 子句?

集計関数を使用せずに SELECT ステートメントで GROUP BY 句を使用すると、DISTINCT 句と同様に動作します。たとえば、次のようなテーブルがあります。 -

mysql> Select * from testing;
+------+---------+---------+
| id   | fname   | Lname   |
+------+---------+---------+
|  200 | Raman   | Kumar   |
|  201 | Sahil   | Bhalla  |
|  202 | Gaurav  | NULL    |
|  203 | Aarav   | NULL    |
|  204 | Harshit | Khurana |
|  205 | Rahul   | NULL    |
|  206 | Piyush  | Kohli   |
|  207 | Lovkesh | NULL    |
|  208 | Gaurav  | Kumar   |
|  209 | Raman  | Kumar    |
+------+---------+---------+
10 rows in set (0.00 sec)

「Lname」列で DISTINCT 句を使用すると、MySQL は次の結果セットを返します。

mysql> select Distinct LNAME from testing;
+---------+
| LNAME   |
+---------+
| Kumar   |
| Bhalla  |
| NULL    |
| Khurana |
| Kohli   |
+---------+
5 rows in set (0.00 sec)

次に、以下に示すように GROUP BY 句を使用すると、DISTINCT -

mysql> Select LNAME from testing GROUP BY Lname;
+---------+
| LNAME   |
+---------+
| NULL    |
| Bhalla  |
| Khurana |
| Kohli   |
| Kumar   |
+---------+
5 rows in set (0.04 sec)

を使用して取得したものと同じ結果セットを取得できます。MySQL によって返される結果を観察できます。セット間の違いとして、GROUP BY 句を使用した MySQL クエリはソートされた結果セットを返しますが、DISTINCT 句を使用した MySQL クエリはソートされていない結果セットを返します。 p>

以上がMySQL の GROUP BY 句はどのように DISTINCT 句のように動作しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はtutorialspoint.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。