当我们对具有多个 NULL 值的列使用 DISTINCT 子句时,MySQL 会返回什么?

mysqlmysqli database更新于 2023/11/11 23:46:00

当我们对具有多个 NULL 值的列使用 DISTINCT 子句时,MySQL 会将所有 NULL 值视为相同。

这意味着根据 DISTINCT 子句的属性,MySQL 将在结果集中仅返回一个 NULL 值并消除其他值。考虑一个名为"testing"的表的示例,该表在列"Lname"中有多个 NULL 值。

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    |
+-----+---------+----------+
8 rows in set (0.00 sec)

mysql> SELECT DISTINCT Lname from testing;
+---------+
| Lname   |
+---------+
| Kumar   |
| Bhalla  |
| NULL    |
| Khurana |
| Kohli   |
+---------+
5 rows in set (0.00 sec)

从上面的查询可以看出,当我们对具有四个 NULL 值的列‘Lname’使用 DISTINCT 子句时,MySQL 仅返回一个 NULL 并消除其他 NULL。


相关文章