题目一:1873. 计算特殊奖金
题目描述:
力扣链接:https://leetcode.cn/problems/calculate-special-bonus/?envType=study-plan&id=sql-beginner&plan=sql&plan_progress=4sjbxye
表: Employees
employee_id 是这个表的主键。
此表的每一行给出了雇员id ,名字和薪水。
写出一个SQL 查询语句,计算每个雇员的奖金。如果一个雇员的id是奇数并且他的名字不是以’M’开头,那么他的奖金是他工资的100%,否则奖金为0。
Return the result table ordered by employee_id.
返回的结果集请按照employee_id排序。
查询结果格式如下面的例子所示。
示例 1:
解释:
因为雇员id是偶数,所以雇员id 是2和8的两个雇员得到的奖金是0。
雇员id为3的因为他的名字以’M’开头,所以,奖金是0。
其他的雇员得到了百分之百的奖金。
解决方案:
MS SQL Server代码:
select employee_id,case when employee_id % 2 = 1 and [name] not like 'M%' then salary else 0 end bonus
from Employees order by employee_id
提交结果:
题目二:627. 变更性别
题目描述:
力扣链接:https://leetcode.cn/problems/swap-salary/?envType=study-plan&id=sql-beginner&plan=sql&plan_progress=4sjbxye
Salary 表:
id 是这个表的主键。
sex 这一列的值是 ENUM 类型,只能从 (‘m’, ‘f’) 中取。
本表包含公司雇员的信息。
请你编写一个 SQL 查询来交换所有的 ‘f’ 和 ‘m’ (即,将所有 ‘f’ 变为 ‘m’ ,反之亦然),仅使用 单个 update 语句 ,且不产生中间临时表。
注意,你必须仅使用一条 update 语句,且 不能 使用 select 语句。
查询结果如下例所示。
示例 1:
解释:
(1, A) 和 (3, C) 从 ‘m’ 变为 ‘f’ 。
(2, B) 和 (4, D) 从 ‘f’ 变为 ‘m’ 。
MS SQL Server代码:
update a set sex = case sex when 'm' then 'f' else 'm' end from Salary a
提交结果:
题目三:196. 删除重复的电子邮箱
题目描述:
力扣链接:https://leetcode.cn/problems/delete-duplicate-emails/description/
表: Person
id是该表的主键列。
该表的每一行包含一封电子邮件。电子邮件将不包含大写字母。
编写一个 SQL 删除语句来 删除 所有重复的电子邮件,只保留一个id最小的唯一电子邮件。
以 任意顺序 返回结果表。 (注意: 仅需要写删除语句,将自动对剩余结果进行查询)
查询结果格式如下所示。
示例 1:
解释: john@example.com重复两次。我们保留最小的Id = 1。
MS SQL Server代码:
delete a from Person a left join
(select min(id) id,email from Person group by email) b
on a.email = b.email
where a.id > b.id
提交结果: