常见的SQL面试题:经典50例

select employee_id, last_name, case department_id when (

select department_id

from departments

where location_id = 1800

) then ‘Canada’ else ‘USA’ end “location”

from employees;

  • 问题:查询员工的employee_id,last_name,要求按照员工的department_name排序

select employee_id, last_name

from employees e1

order by (

select department_name

from departments d1

where e1.department_id = d1.department_id

)

SQL 优化:能使用 EXISTS 就不要使用 IN

  • 问题:查询公司管理者的employee_id,last_name,job_id,department_id信息

select employee_id, last_name, job_id, department_id

from employees

where employee_id in (

select manager_id

from employees

)

select employee_id, last_name, job_id, department_id

from employees e1

where exists (

select ‘x’

from employees e2

where e1.employee_id = e2.manager_id

)

  • 问题:查询departments表中,不存在于employees表中的部门的department_id和department_name

select department_id, department_name

from departments d1

where not exists (

select ‘x’

from employees e1

where e1.department_id = d1.department_id

)

  • 更改 108 员工的信息: 使其工资变为所在部门中的最高工资, job 变为公司中平均工资最低的 job

update employees e1

set salary = (

select max(salary)

from employees e2

where e1.department_id = e2.department_id

), job_id = (

select job_id

from employees

group by job_id

having avg(salary) = (

select min(avg(salary))

from employees

group by job_id

)

)

where employee_id = 108;

  • 删除 108 号员工所在部门中工资最低的那个员工.

delete from employees e1

where salary = (

select min(salary)

from employees

where department_id = (

select department_id

from employees

where employee_id = 108

)

)

select * from employees where employee_id = 108;

select * from employees where department_id = 100

order by salary;

rollback;

常见的SQL面试题:经典50题


已知有如下4张表:

  • 学生表:student(学号,学生姓名,出生年月,性别)

  • 成绩表:score(学号,课程号,成绩)

  • 课程表:course(课程号,课程名称,教师号)

  • 教师表:teacher(教师号,教师姓名)

根据以上信息按照下面要求写出对应的SQL语句。(搜索公众号Java知音,回复“2021”,送你一份Java面试题宝典)

ps:这些题考察SQL的编写能力,对于这类型的题目,需要你先把4张表之间的关联关系搞清楚了,最好的办法是自己在草稿纸上画出关联图,然后再编写对应的SQL语句就比较容易了。下图是我画的这4张表的关系图,可以看出它们之间是通过哪些外键关联起来的:

一、创建数据库和表

为了演示题目的运行过程,我们先按下面语句在客户端navicat中创建数据库和表。

如何你还不懂什么是数据库,什么是客户端navicat,可以先学习这个:

1.创建表
1)创建学生表(student)

按下图在客户端navicat里创建学生表。推荐:250期面试题汇总

学生表的“学号”列设置为主键约束,下图是每一列设置的数据类型和约束

创建完表,点击“保存”

2)创建成绩表(score)

同样的步骤,创建"成绩表“。“课程表的“学号”和“课程号”一起设置为主键约束(联合主键),“成绩”这一列设置为数值类型(float,浮点数值)

3)创建课程表(course)

课程表的“课程号”设置为主键约束

4)教师表(teacher)

教师表的“教师号”列设置为主键约束,教师姓名这一列设置约束为“null”(红框的地方不勾选),表示这一列允许包含空值(null)。推荐:250期面试题汇总

向表中添加数据

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值