题目:
MyNumbers
表:
+-------------+------+ | Column Name | Ty服务器托管网pe | +-------------+------+ | num | int | +-------------+------+ 该表可能包含重复项(换句话说,在SQL中,该表没有主键)。 这张表的每一行都含有一个整数。
单一数字是在MyNumbers
表中只出现一次的数字。
找出最大的单一数字。如果不存在单一数字,则返回null
。
查询结果如下例所示。
解题:
这题,我写了2种方法,第二种是参考答案后写出来的。
select ifnull(max(b.num),null) as num from (select numfrom MyNumbers group by num having count(num) =1) b
其实两者原理类似,都是先规定num的范围,然后再从里面摘选。你觉得哪种更好理解一点?
select ifnull(max(num),null) as num from Mynumbers where num in (select num from MyNumbers group by num having count(num) = 1)
写下来之后,我感觉第二种好像更好理解一点。
服务器托管,北服务器托管网京服务器托管,服务器租用 http://www.fwqtg.net