GitHub:https://github.com/cytues/SQL-p
1.查找最晚入职员工的所有信息
https://github.com/cytues/SQL-p/blob/master/1.txt
2.查找入职员工时间排名倒数第三的员工所有信息
https://github.com/cytues/SQL-p/blob/master/2.txt
3.查找各个部门当前(to_date='9999-01-01')领导当前薪水详情以及其对应部门编号dept_no
https://github.com/cytues/SQL-p/blob/master/3.txt
4.查找所有已经分配部门的员工的last_name和first_name
https://github.com/cytues/SQL-p/blob/master/4.txt
5.查找所有员工的last_name和first_name以及对应部门编号dept_no,也包括展示没有分配具体部门的员工
https://github.com/cytues/SQL-p/blob/master/5.txt
6.查找所有员工入职时候的薪水情况,给出emp_no以及salary, 并按照emp_no进行逆序
https://github.com/cytues/SQL-p/blob/master/6.txt
7.查找薪水涨幅超过15次的员工号emp_no以及其对应的涨幅次数t
https://github.com/cytues/SQL-p/blob/master/7.txt
8.找出所有员工当前(to_date='9999-01-01')具体的薪水salary情况,对于相同的薪水只显示一次,并按照逆序显示
https://github.com/cytues/SQL-p/blob/master/8.txt
9.获取所有部门当前manager的当前薪水情况,给出dept_no, emp_no以及salary,当前表示to_date='9999-01-01'
https://github.com/cytues/SQL-p/blob/master/9.txt
10.获取所有非manager的员工emp_no
https://github.com/cytues/SQL-p/blob/master/10.txt
11.获取所有员工当前的manager,如果当前的manager是自己的话结果不显示,当前表示to_date='9999-01-01'。
https://github.com/cytues/SQL-p/blob/master/11.txt
12.获取所有部门中当前员工薪水最高的相关信息,给出dept_no, emp_no以及其对应的salary
https://github.com/cytues/SQL-p/blob/master/12.txt
13.从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。
https://github.com/cytues/SQL-p/blob/master/13.txt
14.从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。
注意对于重复的emp_no进行忽略。
https://github.com/cytues/SQL-p/blob/master/14.txt
15.查找employees表所有emp_no为奇数,且last_name不为Mary的员工信息,并按照hire_date逆序排列
https://github.com/cytues/SQL-p/blob/master/15.txt
16.统计出当前各个title类型对应的员工当前薪水对应的平均工资。结果给出title以及平均工资avg。
https://github.com/cytues/SQL-p/blob/master/16.txt
17.获取当前(to_date='9999-01-01')薪水第二多的员工的emp_no以及其对应的薪水salary
https://github.com/cytues/SQL-p/blob/master/17.txt
18.查找当前薪水(to_date='9999-01-01')排名第二多的员工编号emp_no、薪水salary、last_name以及first_name,不准使用order by
https://github.com/cytues/SQL-p/blob/master/18.txt
19.查找所有员工的last_name和first_name以及对应的dept_name,也包括暂时没有分配部门的员工
https://github.com/cytues/SQL-p/blob/master/19.txt
20.查找员工编号emp_no为10001其自入职以来的薪水salary涨幅值growth
https://github.com/cytues/SQL-p/blob/master/20.txt
21.查找所有员工自入职以来的薪水涨幅情况,给出员工编号emp_no以及其对应的薪水涨幅growth,并按照growth进行升序
https://github.com/cytues/SQL-p/blob/master/21.txt
22.统计各个部门对应员工涨幅的次数总和,给出部门编码dept_no、部门名称dept_name以及次数sum
https://github.com/cytues/SQL-p/blob/master/22.txt
23.对所有员工的当前(to_date='9999-01-01')薪水按照salary进行按照1-N的排名,相同salary并列且按照emp_no升序排列
https://github.com/cytues/SQL-p/blob/master/23.txt
24.获取所有非manager员工当前的薪水情况,给出dept_no、emp_no以及salary ,当前表示to_date='9999-01-01'
https://github.com/cytues/SQL-p/blob/master/24.txt
25.获取员工其当前的薪水比其manager当前薪水还高的相关信息,当前表示to_date='9999-01-01',
结果第一列给出员工的emp_no,
第二列给出其manager的manager_no,
第三列给出该员工当前的薪水emp_salary,
第四列给该员工对应的manager当前的薪水manager_salary
https://github.com/cytues/SQL-p/blob/master/25.txt
26.汇总各个部门当前员工的title类型的分配数目,结果给出部门编号dept_no、dept_name、其当前员工所有的title以及该类型title对应的数目count
https://github.com/cytues/SQL-p/blob/master/26.txt
27.给出每个员工每年薪水涨幅超过5000的员工编号emp_no、薪水变更开始日期from_date以及薪水涨幅值salary_growth,并按照salary_growth逆序排列。
提示:在sqlite中获取datetime时间对应的年份函数为strftime('%Y', to_date)
https://github.com/cytues/SQL-p/blob/master/27.txt
28.查找描述信息中包括robot的电影对应的分类名称以及电影数目,而且还需要该分类对应电影数量>=5部
https://github.com/cytues/SQL-p/blob/master/28.txt
29.使用join查询方式找出没有分类的电影id以及名称
https://github.com/cytues/SQL-p/blob/master/29.txt
30.使用子查询的方式找出属于Action分类的所有电影对应的title,description
https://github.com/cytues/SQL-p/blob/master/30.txt
31.获取select * from employees对应的执行计划
https://github.com/cytues/SQL-p/blob/master/31.txt
32.将employees表的所有员工的last_name和first_name拼接起来作为Name,中间以一个空格区分
https://github.com/cytues/SQL-p/blob/master/32.txt
33.创建一个actor表,包含如下列信息
列表 | 类型 | 是否为NULL | 含义 |
---|---|---|---|
actor_id | smallint(5) | not null | 主键id |
first_name | varchar(45) | not null | 名字 |
last_name | varchar(45) | not null | 姓氏 |
last_update | timestamp | not null | 最后更新时间,默认是系统的当前时间 |
https://github.com/cytues/SQL-p/blob/master/33.txt
34.对于表actor批量插入如下数据
CREATE TABLE IF NOT EXISTS actor (
actor_id smallint(5) NOT NULL PRIMARY KEY,
first_name varchar(45) NOT NULL,
last_name varchar(45) NOT NULL,
last_update timestamp NOT NULL DEFAULT (datetime('now','localtime')))
actor_id | first_name | last_name | last_update |
---|---|---|---|
1 | PENELOPE | GUINESS | 2006-02-15 12:34:33 |
2 | NICK | WAHLBERG | 2006-02-15 12:34:33 |
https://github.com/cytues/SQL-p/blob/master/34.txt
35.对于表actor批量插入如下数据,如果数据已经存在,请忽略,不使用replace操作
CREATE TABLE IF NOT EXISTS actor (
actor_id smallint(5) NOT NULL PRIMARY KEY,
first_name varchar(45) NOT NULL,
last_name varchar(45) NOT NULL,
last_update timestamp NOT NULL DEFAULT (datetime('now','localtime')))
actor_id | first_name | last_name | last_update |
---|---|---|---|
'3' | 'ED' | 'CHASE' | '2006-02-15 12:34:33' |
https://github.com/cytues/SQL-p/blob/master/35.txt
36.对于如下表actor,其对应的数据为:
actor_id | first_name | last_name | last_update |
---|---|---|---|
1 | PENELOPE | GUINESS | 2006-02-15 12:34:33 |
2 | NICK | WAHLBERG | 2006-02-15 12:34:33 |
创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。 actor_name表结构如下:
列表 | 类型 | 是否为NULL | 含义 |
---|---|---|---|
first_name | varchar(45) | not null | 名字 |
last_name | varchar(45) | not null | 姓氏 |
https://github.com/cytues/SQL-p/blob/master/36.txt
37.针对如下表actor结构创建索引:
CREATE TABLE IF NOT EXISTS actor (
actor_id smallint(5) NOT NULL PRIMARY KEY,
first_name varchar(45) NOT NULL,
last_name varchar(45) NOT NULL,
last_update timestamp NOT NULL DEFAULT (datetime('now','localtime')))
对first_name创建唯一索引uniq_idx_firstname,对last_name创建普通索引idx_lastname
https://github.com/cytues/SQL-p/blob/master/37.txt
38.针对actor表创建视图actor_name_view,只包含first_name以及last_name两列,并对这两列重新命名,first_name为first_name_v,last_name修改为last_name_v:
CREATE TABLE IF NOT EXISTS actor (
actor_id smallint(5) NOT NULL PRIMARY KEY,
first_name varchar(45) NOT NULL,
last_name varchar(45) NOT NULL,
last_update timestamp NOT NULL DEFAULT (datetime('now','localtime')))
https://github.com/cytues/SQL-p/blob/master/38.txt
39.针对salaries表emp_no字段创建索引idx_emp_no,查询emp_no为10005, 使用强制索引。
https://github.com/cytues/SQL-p/blob/master/39.txt
40.存在actor表,包含如下列信息:
CREATE TABLE IF NOT EXISTS actor (
actor_id smallint(5) NOT NULL PRIMARY KEY,
first_name varchar(45) NOT NULL,
last_name varchar(45) NOT NULL,
last_update timestamp NOT NULL DEFAULT (datetime('now','localtime')));
现在在last_update后面新增加一列名字为create_date, 类型为datetime, NOT NULL,默认值为'0000 00:00:00'
https://github.com/cytues/SQL-p/blob/master/40.txt
41.构造一个触发器audit_log,在向employees_test表中插入一条数据的时候,触发插入相关的数据到audit中。
https://github.com/cytues/SQL-p/blob/master/41.txt
42.删除emp_no重复的记录,只保留最小的id对应的记录。
https://github.com/cytues/SQL-p/blob/master/42.txt
43.将所有to_date为9999-01-01的全部更新为NULL,且 from_date更新为2001-01-01。
https://github.com/cytues/SQL-p/blob/master/43.txt
44.将id=5以及emp_no=10001的行数据替换成id=5以及emp_no=10005,其他数据保持不变,使用replace实现。
https://github.com/cytues/SQL-p/blob/master/44.txt
45.将titles_test表名修改为titles_2017。
https://github.com/cytues/SQL-p/blob/master/45.txt
46.在audit表上创建外键约束,其emp_no对应employees_test表的主键id。
https://github.com/cytues/SQL-p/blob/master/46.txt
47.存在如下的视图:
create view emp_v as select * from employees where emp_no >10005;
如何获取emp_v和employees有相同的数据?
https://github.com/cytues/SQL-p/blob/master/47.txt
48.将所有获取奖金的员工当前的薪水增加10%。
https://github.com/cytues/SQL-p/blob/master/48.txt
49.针对库中的所有表生成select count(*)对应的SQL语句
https://github.com/cytues/SQL-p/blob/master/49.txt
50.将employees表中的所有员工的last_name和first_name通过(')连接起来。
https://github.com/cytues/SQL-p/blob/master/50.txt
51.查找字符串'10,A,B' 中逗号','出现的次数cnt。
https://github.com/cytues/SQL-p/blob/master/51.txt
52.获取Employees中的first_name,查询按照first_name最后两个字母,按照升序进行排列
https://github.com/cytues/SQL-p/blob/master/52.txt
53.按照dept_no进行汇总,属于同一个部门的emp_no按照逗号进行连接,结果给出dept_no以及连接出的结果employees
https://github.com/cytues/SQL-p/blob/master/53.txt
54.查找排除当前最大、最小salary之后的员工的平均工资avg_salary。
https://github.com/cytues/SQL-p/blob/master/54.txt
55.分页查询employees表,每5行一页,返回第2页的数据
https://github.com/cytues/SQL-p/blob/master/55.txt
56.获取所有员工的emp_no、部门编号dept_no以及对应的bonus类型btype和recevied,没有分配具体的员工不显示
https://github.com/cytues/SQL-p/blob/master/56.txt
57.使用含有关键字exists查找未分配具体部门的员工的所有信息。
https://github.com/cytues/SQL-p/blob/master/57.txt
58.create view emp_v as select * from employees where emp_no >10005;
CREATE TABLE `employees` (
`emp_no` int(11) NOT NULL,
`birth_date` date NOT NULL,
`first_name` varchar(14) NOT NULL,
`last_name` varchar(16) NOT NULL,
`gender` char(1) NOT NULL,
`hire_date` date NOT NULL,
PRIMARY KEY (`emp_no`));
获取employees中的行数据,且这些行也存在于emp_v中。注意不能使用intersect关键字。
https://github.com/cytues/SQL-p/blob/master/58.txt
59.获取有奖金的员工相关信息。
https://github.com/cytues/SQL-p/blob/master/59.txt
60.按照salary的累计和running_total,其中running_total为前两个员工的salary累计和,其他以此类推。 具体结果如下Demo展示。。
CREATE TABLE `salaries` ( `emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));
https://github.com/cytues/SQL-p/blob/master/60.txt
61.对于employees表中,给出奇数行的first_name