实验四 数据库查询--2

 

1、  查询“王林”的基本情况和所工作的部门名称;

Use yggl

Select name,sex,address,departmentname

From employees,departments

Where employees.departmentid=departmentname.departmentid

And name=’王林’;

 

 

 

2、  查询财务部、研发部、市场部的员工信息(要求使用三种语法分别实现);

(1)    Select *

From employees,salary,departments

Where employees.departmentid=departmentname.departmentid

And employees.employeeid=salary.employeeid

And (departments.departmentname=’研发部

Or departments.departmentname=’财务部

Or departments.departmentname=’市场部’);

 

 

 

(2)

Select *

From employees  join  departments

on employees.departmentid=departmentname.departmentid

where  departments.departmentname=’研发部

Or departments.departmentname=’财务部

Or departments.departmentname=’市场部’;

 

 

 

(3) Select *

From employees  join  departments

Using (departmentid)

where  departments.departmentname=’研发部

Or departments.departmentname=’财务部

Or departments.departmentname=’市场部’;

 

 

 

3、  查询每个雇员的基本情况和薪水情况(要求使用三种语法分别实现);

(1)

Select *

From employees  join  salary

Using(employeeid);

 

2)

Select *

  From employees, salary

Where employees.employeeid=salary.employeeid;

 

 

(3)

Select *

 From employees  join  salary

On employees.employeeid=salary.employeeid;

 

 

4、  查询研发部在1970年以前出生的员工姓名和薪水情况;

Select  name,income,outcome

From employees, salary,departments

Where employees.employeeid=salary.employeeid

And employees.departmentid=departments.departmentid

And departments.departmentname=’研发部

And birthday < ‘1997-01-01’;

 

 

 

5、  查询Employees表中员工的姓名、住址和收入水平,要求2000元以下显示为“低收入”,2000-3000显示为“中等收入”,3000以上显示为“高收入”;

Select name,address,

Case

When income<2000 then ‘低收入

When income>2000  and income<3000  then ‘中等收入

When income > 3000 then ‘高收入

End as 收入水平

From employees,salary

Where employees.employeeid=salary.employeeid;

 

 

6、  查询选修了“计算机基础”这门课的学生的学号、姓名、课程名及成绩(要求使用三种语法分别实现);

(1)

Select xs.学号,xs.姓名,kc.课程名,xs_kc.成绩

From kc,xs,xs_kc

And xs_kc.课程号=kc.课程号

And 课程名=’计算机基础’;

 

(2)

Select xs.学号,xs.姓名,kc.课程名,xs_kc.成绩

From xs  join  xs_kc

On  xs.学号=xs_kc.学号

Join kc

on  xs_kc.课程号=kc.课程号

where 课程名=’计算机基础’;

 

 

(3)
Select xs.学号,xs.姓名,kc.课程名,xs_kc.成绩

From xs  join  xs_kc

Using(学号)

Join kc

Using(课程号)

where 课程名=’计算机基础’;

 

7、  查询kc表中所有学生修过的课程名(使用两种方法:一种连接查询,一种使用group_concat)

(1)

Select distinct kc.课程名,xs_kc.课程号

From kc,xs_kc

Where kc.课程号=xs_kc.课程号;

 

 

 

(2)

 Select distinct  group_concat(课程名)

From kc

Where课程号 in

( select 课程号

From xs_kc

);

 

 

8、  查询所有学生的情况及他们选修的课程号,若学生未选修任何课,也要包括其情况;

Select  xs.*,课程号

From xs left outer join xs_kc

On xs.学号=xs_kc.学号;

 

 

 

 

9、  查询被选修的课程号的选修情况和所有开设的课程名;

Select xs_kc.*,课程名

From  xs_kc  right  join  kc  on xs_kc.课程号=kc.课程号;

 

10、  (子查询)查询选修了102课程的学生学号、姓名;

Select 学号,姓名

From xs

Where  学号 in

(select 学号

From xs_kc

Where 课程号=’102’

);

 

 

 

11、  (子查询)查询选修了“程序设计与语言”这门课的学生学号;

Select 学号

From xs_kc

Where 课程号  in

(select 课程号

From kc

Where 课程名=’程序设计与语言

);

 

 

12、  (子查询)查询选修了“程序设计与语言”这门课的学生姓名、学号;

 

Select 姓名,学号

From  xs

Where 学号 in

(select 学号

From xs_kc

Where 课程号  in

(select  课程号

From kc

Where 课程名=’ 程序设计与语言

)

);

 

 

 

13、  (子查询)查询未选修“程序设计与语言”这门课的学生姓名、学号;

 

  Select 姓名,学号

From  xs

Where 学号  not  in

(select 学号

From xs_kc

Where 课程号  in

(select  课程号

From kc

Where 课程名=’ 程序设计与语言

)

);

 

 

 

14、  (子查询)查询xs表中比所有“通信工程”专业学生年龄都小的学生学号、姓名、出生时间;

 

Select 学号,姓名

From xs

Where 出生时间 >all

(select 出生时间

From xs

Where 专业名=’通信工程

);

 

 

 

15、  (子查询)查询xs表中总学分不低于女生的最低学分的男生的学号、姓名、总学分;

Select  学号,姓名,总学分

From xs

Where 性别=’1’ and 总学分>any

(select 总学分

From xs

Where 性别=’0’

);

 

 

 

16、  (子查询)查询选修了全部课程的学生姓名。

Select 姓名

From xs

Where  not exists

(select *

From kc

Where not exists

(select *

From xs_kc

Where 学号=xs.学号 and 课程号=kc.课程号

)

);

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2018-12-23 21:05  DKPT  阅读(7782)  评论(0编辑  收藏  举报