资讯专栏INFORMATION COLUMN

小李飞刀:SQL题目刷起来!

Cobub / 1454人阅读

摘要:其他用于返回唯一不同的值。编写一个查询,找出每个部门工资最高的员工。例如,根据上述给定的表格,在部门有最高工资,在部门有最高工资。请列出所有超过或等于名学生的课。

随便说说

好几天没有认真刷题了,这两天猛刷了一把SQL题目。
然后用hexo搭建了自己的BLOG,还在摸索中,后续渐渐的就会两边都同步文章。

SQL题集

leetcode上对于数据库是有多带带的19题的,我现在的进度是8/19,刷的还是有点慢,而且很多地方效率不高,还得做n刷处理。
毕竟后续如果考虑到要说数据分析的话,取数上的效率也得保证。

第一题

175. 组合两个表
难度:简单

表1: Person

列名 类型
PersonId int
FirstName varchar
LastName varchar

PersonId 是上表主键
表2: Address

列名 类型
AddressId int
PersonId int
City varchar
State varchar

AddressId 是上表主键

编写一个 SQL 查询,满足条件:无论 person 是否有地址信息,都需要基于上述两表提供 person 的以下信息:
FirstName, LastName, City, State

我的题解:

SELECT Person.FirstName,Person.LastName,Address.City,Address.State
From Person 
Left Join Address
ON Person.PersonId = Address.PersonId

解题思路:
因为无论address可能为空,所以用left join的方式,加入Address表。

其他:
很久没有用过left join,有些概念有点忘记,顺便来复习下知识点。
left join之前的左表是会被完全返回的,哪怕left join的右表没有对应的数据。

select * from table_1 left join table_2

这里的话会返回所有table_1的行。

sql的left join 、right join 、inner join之间的区别
 - left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录
 - right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录
 - inner join(等值连接) 只返回两个表中联结字段相等的行

第二题

176. 第二高的薪水
难度:简单

编写一个 SQL 查询,获取 Employee 表中第二高的薪水(Salary) 。
Id Salary
1 100
2 200
3 300
例如上述 Employee 表,SQL查询应该返回 200 作为第二高的薪水。如果不存在第二高的薪水,那么查询应返回 null。
SecondHighestSalary
200

我的题解:

SELECT MAX(Salary) AS SecondHighestSalary  FROM Employee
WHERE Salary < (SELECT MAX(Salary) FROM Employee)

解题思路:
使用max()来获取两次最大值,因为是同一张表,小于最大值的“最大值”就是第二大的值了。

其他:
一般主要查找最大值,这题查找的是第二大的值。
主要是思路上要调整下,一般程序语言上会做排序。
SQL里面也可以考虑用排序试下,如果要取第二条数据的话,就得先取前两条数据,再倒序取第一条。

第三题

181. 超过经理收入的员工
难度:简单

Employee 表包含所有员工,他们的经理也属于员工。每个员工都有一个 Id,此外还有一列对应员工的经理的 Id。
Id Name Salary ManagerId
1 Joe 70000 3
2 Henry 80000 4
3 Sam 60000 NULL
4 Max 90000 NULL
给定 Employee 表,编写一个 SQL 查询,该查询可以获取收入超过他们经理的员工的姓名。在上面的表格中,Joe 是唯一一个收入超过他的经理的员工。
Employee
Joe

我的题解:

SELECT p1.Name AS Employee FROM Employee p1,Employee p2
WHERE p1.ManagerId = p2.Id
AND p1.Salary > p2.Salary

解题思路:
查询两次同一张表,主条件为匹配经理Id和用户Id,再做比对大小。

其他:
对于同一张表查询两次,其实应该验证下效率到底如何,检查下是否有更快的查询方案。

第四题

182. 查找重复的电子邮箱
难度:简单

编写一个 SQL 查询,查找 Person 表中所有重复的电子邮箱。
示例:
Id Email
1 a@b.com
2 c@d.com
3 a@b.com
根据以上输入,你的查询应返回以下结果:
Email
a@b.com
说明:所有电子邮箱都是小写字母。

我的题解:

SELECT distinct(p1.Email) from Person p1,Person p2
where p1.Email = p2.Email
AND p1.Id != p2.Id

解题思路:
还是查询同一张表两次,然后使用distinct,只输出单个结果。

其他:
distinct用于返回唯一不同的值。
有distinct的字段必须放在开头。

第五题

183. 从不订购的客户
难度:简单

某网站包含两个表,Customers 表和 Orders 表。编写一个 SQL 查询,找出所有从不订购任何东西的客户。
Customers 表:
Id Name
1 Joe
2 Henry
3 Sam
4 Max
Orders 表:
Id CustomerId
1 3
2 1
例如给定上述表格,你的查询应返回:
Customers
Henry
Max

我的题解:

SELECT c.name AS Customers FROM Customers c
WHERE c.Id Not in(SELECT CustomerId FROM Orders)

解题思路:
取出Order表的数据,然后和Customers的Id做校验。

其他:
如果不是用取出Customers的ID来做比较的,就是Id!=CusomerId,而是查询两张表直接输出结果的话,会把每次的不对应的结果都输出。因为等于两张表都被完整比对过一次。

第六题

184. 部门工资最高的员工
难度:中等

Employee 表包含所有员工信息,每个员工有其对应的 Id, salary 和 department Id。
Id Name Salary DepartmentId
1 Joe 70000 1
2 Henry 80000 2
3 Sam 60000 2
4 Max 90000 1
Department 表包含公司所有部门的信息。
Id Name
1 IT
2 Sales
编写一个 SQL 查询,找出每个部门工资最高的员工。例如,根据上述给定的表格,Max 在 IT 部门有最高工资,Henry 在 Sales 部门有最高工资。
Department Employee Salary
IT Max 90000
Sales Henry 80000

我的题解:

select d.Name as Department,e.Name as Employee,e.Salary from Department d,Employee e
where e.DepartmentId = d.ID
and e.Salary = (select max(Salary) from Employee where d.id = DepartmentId)

解题思路:
这题参考了其他人的思路,后续需要自己再写一次。
其实是转了两次弯,第一次是根据部门Id查询出每个部门最高的薪水,再根据这个薪水找到对应的人。

其他:

第七题

196. 删除重复的电子邮箱
难度:简单

编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。
Id Email
1 john@example.com
2 bob@example.com
3 john@example.com

Id 是这个表的主键。

例如,在运行你的查询语句之后,上面的 Person 表应返回以下几行:
Id Email
1 john@example.com
2 bob@example.com

我的题解:

DELETE p1 FROM Person p1,Person p2
WHERE p1.Email = p2.Email and p1.Id > p2.Id

解题思路:
这题一开始也有点被绕住了,后面渐渐做多了两次查询同步一张表就还好,
核心思路就是查询相同的值,且Id不同,我们delete的是Id较大的那一行。

其他:
Null.

第八题

596. 超过5名学生的课
难度:简单
有一个courses 表 ,有: student (学生) 和 class (课程)。
请列出所有超过或等于5名学生的课。

例如,表:
student class
A Math
B English
C Math
D Biology
E Math
F Computer
G Math
H Math
I Math
应该输出:
class
Math

我的题解:

select class From course group by class having count(class)>=5

解题思路:
对课程进行分组,分组后记数大于等于5的就取出数值。

其他
Null

学生在每个课中不应被重复计算。
我的题解:

SELECT class FROM (select distinct * from courses) as new
GROUP BY class HAVING count(*) >= 5

解题思路:
其他:

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/48460.html

相关文章

  • 小李飞刀SQL题目第二弹!

    摘要:执行效率第四题换座位难度中等小美是一所中学的信息科技老师,她有一张座位表,平时用来储存学生名字和与他们相对应的座位。其中纵列的是连续递增的小美想改变相邻俩学生的座位。 写在前面 最近都在忙着折腾Blog的事情,好几天前就做了的题,今天重新刷一遍,有些题目又不太会做了,看来还要三刷才行。主要刷的题目还是SQL相关的,最近感觉时间越来越紧迫了,要更加努力了呢!后续搭建了Gitbook的话,...

    李义 评论0 收藏0
  • 小李飞刀:python我来做题啦

    摘要:好久不见最近都在忙年底的年会,还沉迷于学习统计学,教程还停留在基础语法。做题做题无论如何,数据结构还是很重要的,所以准备每天刷的题目啦。第一题移除元素给定一个数组和一个值,你需要原地移除所有数值等于的元素,返回移除后数组的新长度。 好久不见 最近都在忙年底的年会,还沉迷于学习统计学,python教程还停留在基础语法。但是仔细规划了下,还是要好好的瞄准目标前行。所以准备呢,实战走起来。 ...

    nevermind 评论0 收藏0
  • 小李飞刀:python你慢点飞,我的脑子还在后面追

    摘要:默认参数设置默认参数时,有几点要注意一是必选参数在前,默认参数在后,否则的解释器会报错二是如何设置默认参数。注意此处,获得的其实是的拷贝,函数内对的改变不会影响到。使用递归函数需要注意防止栈溢出。 总是在最前面的叨逼叨 最近总是在想成长这两个很常常被提起的事情,这对于一个已经25岁的半中年而言,已经是一个不太能高频提起的词。但是,最近一些事情吧,总让我觉得我的生长期似乎比正常人来的晚了...

    kevin 评论0 收藏0
  • 小李飞刀:ppppppython是需要好好学习的

    摘要:直接抄其中一份的结论吧各地区招聘公司数量和平均待遇。可以看出不论是招聘公司的数据还是平均待遇水平主要都是北上广深杭州占优势。但事实证明,总是要有一些代价的。要学会看报错信息。函数定义结束后需要按两次回车重新回到提示符下。 又是写在前面的乱七八糟 持续学习的第三天了,持续学习是一个不容易培养的好习惯,但是坚持就是胜利嘛~昨天因为一点点事情,所以没能学习很长时间,今天要补回来。周末要搬家,...

    Simon 评论0 收藏0
  • 小李飞刀:leetcode我又来啦~

    摘要:在拖完地板之后,想想还是补上今天的题解吧感谢小佳扬推荐的题目,默默的复习了一把递归第一题难度中等实现,即计算的次幂函数。因为是次幂,如果直接循环,复杂度就是了。次幂可以拆解为的方式。每次拆解,最后最小的单位应该为。 写在前面 年前嘛,就是各种涣散的状态。在拖完地板之后,想想还是补上今天的题解吧~感谢小佳扬推荐的题目,默默的复习了一把递归~ 第一题 50. Pow(x, n)难度:中等 ...

    zhangxiangliang 评论0 收藏0

发表评论

0条评论

Cobub

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<