大的国家
题目:
如果一个国家满足下述两个条件之一,则认为该国是 大国 :
面积至少为 300 平方公里(即,3000000 km2),或者 人口至少为 2500 万(即 25000000) 编写一个 SQL
查询以报告 大国 的国家名称、人口和面积。按 任意顺序 返回结果表。
查询结果格式如下例所示。
解析:至少的表示 >=
select name,population,area
from World
where area >= 3000000 or population >= 25000000;
寻找用户推荐人
题目:
给定表 customer ,里面保存了所有客户信息和他们的推荐人。 写一个查询语句,返回一个客户列表,列表中客户的推荐人的编号都 不是 2。
解析:推荐人的编号可能是null IS NULL
select name
from customer
where referee_id != 2 or referee_id IS null;
从不订购的客户
题目:
某网站包含两个表,Customers 表和 Orders 表。编写一个 SQL 查询,找出所有从不订购任何东西的客户。
解析:先查出有订单的客户 not in
select Name as Customers
from Customers
where Customers.id not in
(
select CustomerId from Orders
);
计算特殊奖金
题目:
写出一个SQL
查询语句,计算每个雇员的奖金。如果一个雇员的id是奇数并且他的名字不是以’M’开头,那么他的奖金是他工资的100%,否则奖金为0。Return the result table ordered by employee_id.
返回的结果集请按照employee_id排序。
解析:奇数用mod()函数计算,名字用like,整体用case when
select employee_id ,
(case when mod(employee_id,2)!=0 and name not like 'M%' then salary else 0 end) as bonus
from Employees
order by employee_id
语法详解:
- 求余函数
MOD(x,y)
返回x被y除后的余数,MOD()对于带有小数部分的数值也起作用。
- 字符匹配
[NOT] LIKE
四种通配符:
_:匹配任意一个字符;
%:匹配0个或多个字符;
[ ]:匹配[ ]中的任意一个字符(若要比较的字符是连续的,则可以用连字符“-”表 达 );
[^]:不匹配[ ]中的任意一个字符。
- CASE WHEN
CASE WHEN condition THEN result
[WHEN...THEN...]
ELSE result
END
condition是一个返回布尔类型的表达式,如果表达式返回true,则整个函数返回相应result的值,如果表达式皆为false,则返回ElSE后result的值,如果省略了ELSE子句,则返回NULL。
THEN后边的值与ELSE后边的值类型应一致。
题目来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/big-countries
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
参考文章:
SQL-字符匹配:
https://blog.csdn.net/hcc13974721431/article/details/121781332
SQL之CASE WHEN基础用法详解(一):https://www.cnblogs.com/Rui6/p/15708510.html