SQL|练习笔记

大的国家

题目:

如果一个国家满足下述两个条件之一,则认为该国是 大国 :

面积至少为 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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值