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

当我们在具有多个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并消除其他值。

猜你喜欢