1. ---------PS:但凡有聚合函数(where),必然后Group byGroup by后面跟having
    ---------面试题
  1. SELECT name,sum(fen) as s
  2. from score
  3. GROUP BY NAME
  4. ORDER BY s;
  1.  
  2. PS:一般聚合查询后面跟having

SELECT title, COUNT(DISTINCT emp_no) AS t FROM titles  --内部再次过滤
GROUP BY title HAVING t >= 2

  1. 分页查询

查询第1条到第10条的数据的sql是:select * from table limit 0,10;   ->对应我们的需求就是查询第一页的数据:select * from table limit (1-1)*10,10;

  1.  

查询第10条到第20条的数据的sql是:select * from table limit 10,20;  ->对应我们的需求就是查询第二页的数据:select * from table limit (2-1)*10,10;

  1.  

查询第20条到第30条的数据的sql是:select * from table limit 20,30;  ->对应我们的需求就是查询第三页的数据:select * from table limit (3-1)*10,10;

  1. ------------------题目---------------------
  2. --1.查找最晚入职员工的所有信息
  3. CREATE TABLE `employees` (
  4. `emp_no` int(11) NOT NULL,
  5. `birth_date` date NOT NULL,
  6. `first_name` varchar(14) NOT NULL,
  7. `last_name` varchar(16) NOT NULL,
  8. `gender` char(1) NOT NULL,
  9. `hire_date` date NOT NULL,
  10. PRIMARY KEY (`emp_no`));
  11. --答案:
  12. --子查询
  13. SELECT * FROM employees WHERE hire_date = (SELECT MAX(hire_date) FROM employees);
  14. --排序
  15. SELECT * FROM employees ORDER BY hire_date DESC LIMIT 0,1;
  16. --2.查找入职员工时间排名倒数第三的员工所有信息
  17. SELECT * FROM employees ORDER BY hire_date DESC LIMIT 2,1;
  18.  
  19. --3.查找各个部门当前(to_date='9999-01-01')领导当前薪水详情以及其对应部门编号dept_no
  20. CREATE TABLE `dept_manager` (
  21. `dept_no` char(4) NOT NULL,
  22. `emp_no` int(11) NOT NULL,
  23. `from_date` date NOT NULL,
  24. `to_date` date NOT NULL,
  25. PRIMARY KEY (`emp_no`,`dept_no`));
  26.  
  27. CREATE TABLE `salaries` (
  28. `emp_no` int(11) NOT NULL,
  29. `salary` int(11) NOT NULL,
  30. `from_date` date NOT NULL,
  31. `to_date` date NOT NULL,
  32. PRIMARY KEY (`emp_no`,`from_date`));
  33. --Answer:
  34. select
  35. salaries.emp_no,salaries.salary,salaries.from_date,salaries.to_date,dept_manager.dept_no
  36. from salaries inner join dept_manager
  37. on dept_manager.emp_no = salaries.emp_no
  38. where dept_manager.to_date = '9999-01-01' --没想起来
  39. and salaries.to_date = '9999-01-01';
  40.  
  41. --4.查找所有已经分配部门的员工的last_namefirst_name
  42. -- 内链接推荐
  43. SELECT e.last_name,e.first_name,d.dept_no
  44. FROM dept_emp d INNER JOIN employees e
  45. ON d.emp_no = e.emp_no
  46.  
  47. --left join(左连接):join左表中所有记录和右表中满足连接条件的记录信息
  48. --right join(右连接):join右表中所有记录和左表中满足连接条件的记录信息
  49. --5.查找所有员工的last_namefirst_name以及对应部门编号dept_no
  50. SELECT e.last_name,e.first_name,d.dept_no
  51. FROM employees e LEFT JOIN dept_emp d
  52. ON d.emp_no = e.emp_no;
  53.  
  54. --6.查找所有员工入职时候的薪水情况,给出emp_no以及salary 并按照emp_no进行逆序
  55. SELECT e.emp_no,s.salary
  56. FROM employees e INNER JOIN salaries s
  57. ON s.emp_no = e.emp_no AND e.hire_date = s.from_date --少考虑这一种情况
  58. ORDER BY e.emp_no DESC;
  59.  
  60. --7.查找薪水涨幅超过15次的员工号emp_no以及其对应的涨幅次数t
  61. -- 本题主要考聚合查询
  62. SELECT emp_no, COUNT(emp_no) AS t
  63. FROM salaries
  64. GROUP BY emp_no HAVING t>15;
  65.  
  66. --8.找出所有员工当前(to_date='9999-01-01')具体的薪水salary情况,对于相同的薪水只显示一次,并按照逆序显示
  67. SELECT DISTINCT(salary)
  68. FROM salaries
  69. WHERE to_date='9999-01-01'
  70. ORDER BY salary DESC;
  71.  
  72. --9.获取所有部门当前manager的当前薪水情况,给出dept_no, emp_no以及salary,当前表示to_date='9999-01-01'
  73. -- PS: on已经是条件的判断了,不能再用where, INNER JOIN 左右两表交换 没有 错,oj有问题
  74. SELECT d.dept_no,d.emp_no,s.salary
  75. FROM dept_manager d INNER JOIN salaries s
  76. ON s.emp_no = d.emp_no
  77. AND d.to_date = '9999-01-01'
  78. AND s.to_date = '9999-01-01'
  79. ---WHERE to_date='9999-01-01';
  80. ---注:有人反映将连接语句改成FROM dept_manager AS d INNER JOIN salaries AS s后,结果通不过。
  81. --INNER JOIN对于左右两表并无顺序要求,此为本题OJ系统Bug所致。
  82.  
  83. --10.获取所有非manager的员工emp_no !!!!!!
  84. -- -PS:考察NOT IN
  85. --方法一:使用NOT IN选出在employees但不在dept_manager中的emp_no记录
  86. SELECT emp_no FROM employees
  87. WHERE emp_no NOT IN (SELECT emp_no FROM dept_manager)
  88.  
  89. -- 方法二:先使用LEFT JOIN连接两张表,再从此表中选出dept_no值为NULL对应的emp_no记录
  90. SELECT emp_no?FROM?(SELECT * FROM employees LEFT JOIN dept_manager
  91. ON employees.emp_no = dept_manager.emp_no)
  92. WHERE dept_no IS NULL
  93.  
  94. --11.获取所有员工当前的manager,如果当前的manager是自己的话结果不显示,当前表示to_date='9999-01-01'
  95. --结果第一列给出当前员工的emp_no,第二列给出其manager对应的manager_no
  96.  
  97. SELECT de.emp_no, dm.emp_no AS manager_no?
  98. FROM dept_emp AS de INNER JOIN dept_manager AS dm
  99. ON de.dept_no = dm.dept_no?
  100. WHERE dm.to_date = '9999-01-01' AND de.emp_no <> dm.emp_no
  101.  
  102. --12.获取所有部门中当前员工薪水最高的相关信息,给出dept_no, emp_no以及其对应的salary
  103. SELECT de.dept_no,de.emp_no,MAX(sa.salary) AS salary
  104. FROM dept_emp AS de INNER JOIN salaries AS sa
  105. ON de.emp_no = sa.emp_no
  106. WHERE de.to_date = '9999-01-01' AND sa.to_date = '9999-01-01'
  107. GROUP BY de.dept_no
  108.  
  109. --13.titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t
  110. --PS:正确的过滤是在having以后过滤
  111. SELECT title,COUNT(title) AS t
  112. FROM titles
  113. WHERE t>=2 --错误
  114. GROUP BY title
  115. -- 正确的答案
  116. SELECT title, COUNT(title) AS t FROM titles
  117. GROUP BY title HAVING t >= 2; --- 聚合就聚合到这里了
  118.  
  119. --14.titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。注意对于重复的emp_no进行忽略。
  120. --PS:对COUNT中进行分解
  121. SELECT title, COUNT(DISTINCT emp_no) AS t FROM titles
  122. GROUP BY title HAVING t >= 2
  123.  
  124. --15.查找employees表所有emp_no为奇数,且last_name不为Mary的员工信息,并按照hire_date逆序排列
  125. SELECT *
  126. FROM employees
  127. WHERE emp_no%2 = 1 AND last_name!='Mary'
  128. ORDER BY hire_date DESC;
  129.  
  130. --16 .统计出当前各个title类型对应的员工当前薪水对应的平均工资。结果给出title以及平均工资avg
  131. --PS:不知道为什么不行
  132. --SELECT t.title AVG(s.salary);
  133. --FROM salaries s INNER JOIN titles t
  134. --ON s.emp_no = t.emp_no AND t.to_date='9999-01-01' AND s.to_date='9999-01-01'
  135. --GROUP BY title
  136.  
  137. select t.title,avg(s.salary) from titles t, salaries s where
  138. s.emp_no = t.emp_no
  139. and s.to_date =?'9999-01-01'
  140. and t.to_date =?'9999-01-01'
  141. group by title
  142.  
  143. --17.获取当前(to_date='9999-01-01')薪水第二多的员工的emp_no以及其对应的薪水salary
  144. SELECT emp_no,salary
  145. FROM salaries
  146. WHERE to_date='9999-01-01'
  147. ORDER BY salary DESC --注意要降序
  148. LIMIT 1,1
  149.  
  150. --18.查找当前薪水(to_date='9999-01-01')排名第二多的员工编号emp_no、薪水salarylast_name以及first_name,不准使用order by
  151. SELECT e.emp_no, MAX(s.salary) AS salary, e.last_name, e.first_name
  152. FROM employees AS e INNER JOIN salaries AS s
  153. ON e.emp_no = s.emp_no
  154. AND s.to_date = '9999-01-01'
  155. AND s.salary NOT IN (
  156. SELECT MAX(salary) FROM salaries
  157. WHERE salaries.to_date = '9999-01-01');
  158.  
  159. --19.查找所有员工的last_namefirst_name以及对应的dept_name,也包括暂时没有分配部门的员工
  160. --毁三观!!!!!!
  161.  
  162. --1、第一次LEFT
  163. --JOIN连接employees表与dept_emp表,得到所有员工的last_namefirst_name以及对应的dept_no,也包括暂时没有分配部门的员工
  164. --2、第二次LEFT
  165. --JOIN连接上表与departments表,即连接dept_nodept_name,得到所有员工的last_namefirst_name以及对应的dept_name,也包括暂时没有分配部门的员工
  166. select e.last_name,e.first_name,d.dept_name
  167. from employees e
  168. left join dept_emp de on e.emp_no =de.emp_no
  169. left join departments d on d.dept_no=de.dept_no;
  170.  
  171. --20.查找员工编号emp_now10001其自入职以来的薪水salary涨幅值growth
  172. SELECT (MAX(salary)-MIN(salary)) AS growth
  173. FROM salaries WHERE emp_no = ''
  174. --16 .统计出当前各个title类型对应的员工当前薪水对应的平均工资。结果给出title以及平均工资avg
  175. --PS:不知道为什么不行
  176. --SELECT t.title AVG(s.salary);
  177. --FROM salaries s INNER JOIN titles t
  178. --ON s.emp_no = t.emp_no AND t.to_date='9999-01-01' AND s.to_date='9999-01-01'
  179. --GROUP BY title
  180.  
  181. select t.title,avg(s.salary) from titles t, salaries s where
  182. s.emp_no = t.emp_no
  183. and s.to_date =?'9999-01-01'
  184. and t.to_date =?'9999-01-01'
  185. group by title
  186.  
  187. --17.获取当前(to_date='9999-01-01')薪水第二多的员工的emp_no以及其对应的薪水salary
  188. SELECT emp_no,salary
  189. FROM salaries
  190. WHERE to_date='9999-01-01'
  191. ORDER BY salary DESC --注意要降序
  192. LIMIT 1,1
  193.  
  194. --18.查找当前薪水(to_date='9999-01-01')排名第二多的员工编号emp_no、薪水salarylast_name以及first_name,不准使用order by
  195. SELECT e.emp_no, MAX(s.salary) AS salary, e.last_name, e.first_name
  196. FROM employees AS e INNER JOIN salaries AS s
  197. ON e.emp_no = s.emp_no
  198. AND s.to_date = '9999-01-01'
  199. AND s.salary NOT IN (
  200. SELECT MAX(salary) FROM salaries
  201. WHERE salaries.to_date = '9999-01-01');
  202.  
  203. --19.查找所有员工的last_namefirst_name以及对应的dept_name,也包括暂时没有分配部门的员工
  204. --毁三观!!!!!!
  205.  
  206. --1、第一次LEFT
  207. --JOIN连接employees表与dept_emp表,得到所有员工的last_namefirst_name以及对应的dept_no,也包括暂时没有分配部门的员工
  208. --2、第二次LEFT
  209. --JOIN连接上表与departments表,即连接dept_nodept_name,得到所有员工的last_namefirst_name以及对应的dept_name,也包括暂时没有分配部门的员工
  210. select e.last_name,e.first_name,d.dept_name
  211. from employees e
  212. left join dept_emp de on e.emp_no =de.emp_no
  213. left join departments d on d.dept_no=de.dept_no;
  214.  
  215. --20.查找员工编号emp_now10001其自入职以来的薪水salary涨幅值growth
  216. SELECT (MAX(salary)-MIN(salary)) AS growth
  217. FROM salaries WHERE emp_no = ''
  218.  
  219. --21.查找所有员工自入职以来的薪水涨幅情况,给出员工编号emp_noy以及其对应的薪水涨幅growth,并按照growth进行升序
  220. select t1.emp_no, t1.salary - t2.salary as growth
  221. from
  222. (select e.emp_no,s.salary from salaries s,employees e where e.emp_no=s.emp_no and s.to_date='9999-01-01' )as t1,
  223. (select e.emp_no,s.salary from salaries s,employees e where e.emp_no=s.emp_no and s.from_date=e.hire_date)as t2
  224. where t1.emp_no=t2.emp_no
  225. order by growth;
  226.  
  227. --22.统计各个部门对应员工涨幅的次数总和,给出部门编码dept_no、部门名称dept_name以及次数sum
  228. -- 多个表查询,可以多次链接
  229. SELECT de.dept_no, dp.dept_name, COUNT(s.salary) AS sum?
  230. FROM (dept_emp AS de INNER JOIN salaries AS s ON de.emp_no = s.emp_no)?
  231. INNER JOIN departments AS dp ON de.dept_no = dp.dept_no?
  232. GROUP BY de.dept_no
  233.  
  234. --23.对所有员工的当前(to_date='9999-01-01')薪水按照salary进行按照1-N的排名,相同salary并列且按照emp_no升序排列
  235. SELECT emp_no,salary, AS rank
  236. FROM salaries
  237. WHERE to_date='9999-01-01'
  238. ORDER BY emp_no
  239.  
  240. --24.对所有员工的当前(to_date='9999-01-01')薪水按照salary进行按照1-N的排名,相同salary并列且按照emp_no升序排列
  241. select s1.emp_no , s1.salary ,count(distinct s2.salary) as rank
  242. from salaries s1, salaries s2
  243. where s1.to_date = '9999-01-01' and s2.to_date = '9999-01-01' and
  244. s1.salary<=s2.salary --最大的数只小于等于自己,第二大的数只小于等于两个数,以此类推。。。为他们的rank
  245. group by s1.emp_no
  246. order by rank ;
  247.  
  248. --25.获取所有非manager员工当前的薪水情况,给出dept_noemp_no以及salary ,当前表示to_date='9999-01-01'
  249.  
  250. SELECT de.dept_no, s.emp_no, s.salary?
  251. FROM (employees AS e INNER JOIN salaries AS s ON s.emp_no = e.emp_no AND s.to_date = '9999-01-01')
  252. INNER JOIN dept_emp AS de ON e.emp_no = de.emp_no
  253. WHERE de.emp_no NOT IN (SELECT emp_no FROM dept_manager)
  1. --25.获取员工其当前的薪水比其manager当前薪水还高的相关信息,当前表示to_date='9999-01-01',结果第一列给出员工的emp_no,第二列给出其managermanager_no,第三列给出该员工当前的薪水emp_salary,第四列给该员工对应的manager当前的薪水manager_salary
  2. --SELECT
  3. --FROM dept_emp e INNER JOIN dept_manager m
  4. --ON e.emp_no = m.emp_no
  5.  
  6. --本题主要思想是创建两张表(一张记录当前所有员工的工资,另一张只记录部门经理的工资)进行比较,具体思路如下:
  7. -- 1、先用INNER JOIN连接salariesdemp_emp,建立当前所有员工的工资记录sem
  8. -- 2、再用INNER JOIN连接salariesdemp_manager,建立当前所有员工的工资记录sdm
  9. -- 3、最后用限制条件sem.dept_no = sdm.dept_no AND sem.salary >
  10. -- sdm.salary找出同一部门中工资比经理高的员工,并根据题意依次输出emp_nomanager_noemp_salarymanager_salary
  11.  
  12. SELECT sem.emp_no AS emp_no, sdm.emp_no AS manager_no, sem.salary AS emp_salary, sdm.salary AS manager_salary
  13. FROM (SELECT s.salary, s.emp_no, de.dept_no FROM salaries s INNER JOIN dept_emp de
  14. ON s.emp_no = de.emp_no AND s.to_date = '9999-01-01' ) AS sem, 
  15. (SELECT s.salary, s.emp_no, dm.dept_no FROM salaries s INNER JOIN dept_manager dm
  16. ON s.emp_no = dm.emp_no AND s.to_date = '9999-01-01' ) AS sdm
  17. WHERE sem.dept_no = sdm.dept_no AND sem.salary > sdm.salary
  18.  
  19. --26.汇总各个部门当前员工的title类型的分配数目,结果给出部门编号dept_nodept_name、其当前员工所有的title以及该类型title对应的数目count
  20. --PS:对一个表进行连接以后,可以再连接两一个表
  21.  
  22. 本题的关键在于用 GROUP BY 同时对 de.dept_no t.title
  23. 进行分组,具体思路如下:
  24. 1、先用 INNER JOIN 连接 dept_emp salaries,根据测试数据添加限定条件 de.to_date =
  25. '9999-01-01' AND t.to_date = '9999-01-01',即当前员工的当前头衔
  26. 2、再用 INNER JOIN 连接departments,限定条件为 de.dept_no =
  27. dp.dept_no,即部门编号相同
  28. 3、最后用 GROUP BY 同时对 de.dept_no t.title 进行分组,用 COUNT(t.title)
  29. 统计相同部门下相同头衔的员工个数
  30.  
  31. SELECT de.dept_no, dp.dept_name, t.title, COUNT(t.title) AS count
  32. FROM titles AS t INNER JOIN dept_emp AS de 
  33. ON t.emp_no = de.emp_no AND de.to_date = '9999-01-01' AND t.to_date = '9999-01-01'
  34. INNER JOIN departments AS dp 
  35. ON de.dept_no = dp.dept_no
  36. GROUP BY de.dept_no, t.title
  37.  
  38. --27.给出每个员工每年薪水涨幅超过5000的员工编号emp_no、薪水变更开始日期from_date以及薪水涨幅值salary_growth,并按照salary_growth逆序排列。
  39. -- 提示:在sqlite中获取datetime时间对应的年份函数为strftime('%Y', to_date)
  40.  
  41. --SELECT emp_no,from_date, AS salary_growth
  42. --FROM salaries
  43.  
  44. SELECT s2.emp_no, s2.from_date, (s2.salary - s1.salary) AS salary_growth
  45. FROM salaries AS s1, salaries AS s2
  46. WHERE s1.emp_no = s2.emp_no 
  47. AND salary_growth > 5000
  48. AND (strftime("%Y",s2.to_date) - strftime("%Y",s1.to_date) = 1 
  49.      OR strftime("%Y",s2.from_date) - strftime("%Y",s1.from_date) = 1 )
  50. ORDER BY salary_growth DESC
  51.  
  52. --28.查找描述信息中包括robot的电影对应的分类名称以及电影数目,而且还需要该分类对应电影数量>=5
  53.  
  54. SELECT c.name AS name, COUNT(c.name) AS amount
  55. FROM (film AS f INNER JOIN film_category AS fc ON f.film_id = fc.film_id )
  56. INNER JOIN category AS c
  57. ON fc.category_id = c.category_id
  58. WHERE f.description LIKE '%robot%'
  59. GROUP BY c.name HAVING amount >= 2
  60.  
  61. --29.使用join查询方式找出没有分类的电影id以及名称
  62.  
  63. SELECT f.film_id, f.title FROM film f LEFT JOIN film_category fc
  64. ON f.film_id = fc.film_id WHERE fc.category_id IS NULL
  65.  
  66. --30.使用子查询的方式找出属于Action分类的所有电影对应的title,description
  67.  
  68. SELECT f.title, f.description 
  69. FROM film f, film_category fc, category c
  70. WHERE f.film_id = fc.film_id 
  71. AND fc.category_id = c.category_id 
  72. AND c.name = 'Action'
  73.  
  74. --32.employees表的所有员工的last_namefirst_name拼接起来作为Name,中间以一个空格区分
  75.  
  76. --不同数据库连接字符串的方法不完全相同,MySQLSQL
  77. --ServerOracle等数据库支持CONCAT方法,而本题所用的SQLite数据库只支持用连接符号"||"来连接字符串
  78.  
  79. SELECT last_name||" "||first_name AS Name FROM employees
  80.  
  81. --33.创建一个actor表,包含如下列信息
  82.  
  83. CREATE TABLE IF NOT EXISTS actor
  84. (
  85. actor_id smallint(5) NOT NULL PRIMARY KEY,
  86. first_name varchar(45) NOT NULL,
  87. last_name varchar(45) NOT NULL,
  88. last_update timestamp NOT NULL DEFAULT (datetime('now','localtime'))
  89. )
  90.  
  91. --34.批量插入数据
  92.  
  93. INSERT INTO actor
  94. VALUES (1, 'PENELOPE', 'GUINESS', '2006-02-15 12:34:33'),
  95. (2, 'NICK', 'WAHLBERG', '2006-02-15 12:34:33')
  96.  
  97. --35.批量插入数据
  98. INSERT OR IGNORE INTO actor VALUES (3, 'ED', 'CHASE', '2006-02-15 12:34:33')
  99.  
  100. --36.创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。 actor_name表结构如下:
  101.  
  102. CREATE TABLE actor_name
  103. (
  104. first_name varchar(45) NOT NULL,
  105. last_name varchar(45) NOT NULL
  106. );
  107. INSERT INTO actor_name SELECT first_name, last_name FROM actor;
  108.  
  109. --37.first_name创建唯一索引uniq_idx_firstname,对last_name创建普通索引idx_lastname
  110.  
  111. CREATE UNIQUE INDEX uniq_idx_firstname ON actor(first_name);
  112. CREATE INDEX idx_lastname ON actor(last_name);
  113.  
  114. --38.针对actor表创建视图actor_name_view,只包含first_name以及last_name两列,并对这两列重新命名,fist_namefirst_name_vlast_name修改为last_name_v
  115. CREATE TABLE IF NOT EXISTS actor (
  116. actor_id smallint(5) NOT NULL PRIMARY KEY,
  117. first_name varchar(45) NOT NULL,
  118. last_name varchar(45) NOT NULL,
  119. last_update timestamp NOT NULL DEFAULT (datetime('now','localtime')))
  120. -------------------------------
  121. --视图是用来干什么的?视图时虚表,仅存储建立视图的sql语句,查询的时候跟普通的表一样,
  122. CREATE VIEW actor_name_view AS
  123. SELECT first_name AS fist_name_v, last_name AS last_name_v
  124. FROM actor 
  125.  
  126. --39.针对salariesemp_no字段创建索引idx_emp_no,查询emp_no10005, 使用强制索引。
  127. SELECT * FROM salaries INDEXED BY idx_emp_no WHERE emp_no='';
  128.  
  129. --40.现在在last_update后面新增加一列名字为create_date, 类型为datetime, NOT NULL,默认值为'0000 00:00:00'
  130. --ADD COLUMN create_date
  131. ALTER TABLE actor ADD COLUMN create_date datetime NOT NULL DEFAULT '0000-00-00 00:00:00';
  132.  
  133. --41.构造一个触发器audit_log,在向employees表中插入一条数据的时候,触发插入相关的数据到audit中。
  134. CREATE TRIGGER audit_log AFTER INSERT ON employees_test
  135. BEGIN
  136. INSERT INTO audit VALUES (NEW.ID, NEW.NAME);
  137. END;
  138.  
  139. --42.删除emp_no重复的记录,只保留最小的id对应的记录。
  140. DELETE FROM titles_test WHERE id NOT IN
  141. (SELECT MIN(id) FROM titles_test GROUP BY emp_no);
  142.  
  143. --43.将所有to_date9999-01-01的全部更新为NULL,且 from_date更新为2001-01-01
  144. UPDATE FROM titles_test SET to_date =NULL, from_date='2001-01-01'
  145. WHERE to_date='9999-01-01';
  146.  
  147. --44.id=5以及emp_no=10001的行数据替换成id=5以及emp_no=10005,其他数据保持不变,使用replace实现。
  148. update titles_test set emp_no=replace(emp_no,'','') where id=''
  149.  
  150. --45.titles_test表名修改为titles_2017
  151. -- RENAME TABLE titles_test AS titles_2017;
  152. ALTER TABLE titles_test RENAME TO titles_2017;
  153.  
  154. --46.audit表上创建外键约束,其emp_no对应employees_test表的主键id
  155. --CREATE FOREIGN KEY for REFERENCES ON
  156.  
  157. --47.存在如下的视图:create view emp_v as select * from employees where emp_no >10005;如何获取emp_vemployees有相同的数据?
  158. --PS :使用INTERSECT取交集
  159. SELECT * FROM employees INTERSECT SELECT * FROM emp_v
  160.  
  161. --48.将所有获取奖金的员工当前的薪水增加10%。
  162. update salaries
  163. set salary=1.1*salary
  164. where emp_no in (select emp_no from emp_bonus)
  165.  
  166. --50.employees表中的所有员工的last_namefirst_name通过(')连接起来。
  167. SELECT last_name || "'" || first_name AS name FROM employees;
  168.  
  169. --51.查找字符串'10,A,B' 中逗号','出现的次数cnt
  170. SELECT (length("10,A,B")-length(replace("10,A,B",",","")))/length(",") AS cnt
  171.  
  172. --52.获取Employees中的first_name,查询按照first_name最后两个字母,按照升序进行排列
  173. SELECT first_name
  174. FROM employees
  175. ORDER BY substr(first_name,-2) ;
  176.  
  177. --53.按照dept_no进行汇总,属于同一个部门的emp_no按照逗号进行连接,结果给出dept_no以及连接出的结果employees
  178. --SELECT dept_no,(SELECT ) AS employees
  179. --FROM dept_emp
  180.  
  181. --本题要用到SQLite的聚合函数group_concat(X,Y),其中X是要连接的字段,Y是连接时用的符号,可省略,默认为逗号。此函数必须与 GROUP BY 配合使用。此题以 dept_no 作为分组,将每个分组中不同的emp_no用逗号连接起来(即可省略Y)。可参考: http://www.sqlite.org/lang_aggfunc.html#groupconcat http://blog.csdn.net/langzxz/article/details/16807859 1
  182.  
  183. SELECT dept_no, group_concat(emp_no) AS employees
  184. FROM dept_emp GROUP BY dept_no
  185.  
  186. --54.查找排除当前最大、最小salary之后的员工的平均工资avg_salary。
  187. --PS:不会选择最大和最小
  188. --SELECT AVG(salary) AS avg_salary
  189. --FROM salaries
  190.  
  191. SELECT AVG(salary) AS avg_salary FROM salaries 
  192. WHERE to_date = '9999-01-01' 
  193. AND salary NOT IN (SELECT MAX(salary) FROM salaries WHERE to_date = '9999-01-01')
  194. AND salary NOT IN (SELECT MIN(salary) FROM salaries WHERE to_date = '9999-01-01')
  195.  
  196. --55.分页查询employees表,每5行一页,返回第2页的数据
  197. SELECT * FROM employees LIMIT 5,5
  198.  
  199. --56.获取所有员工的emp_no、部门编号dept_no以及对应的bonus类型btype和recevied,没有分配具体的员工不显示
  200.  
  201. SELECT em.emp_no, de.dept_no, eb.btype, eb.recevied
  202. FROM employees AS em INNER JOIN dept_emp AS de
  203. ON em.emp_no = de.emp_no
  204. LEFT JOIN emp_bonus AS eb 
  205. ON de.emp_no = eb.emp_no
  206.  
  207. --57.使用含有关键字exists查找未分配具体部门的员工的所有信息。
  208.  
  209. SELECT * FROM employees WHERE NOT EXISTS 
  210. (SELECT emp_no FROM dept_emp WHERE emp_no = employees.emp_no)
  211.  
  212. SELECT * FROM employees WHERE emp_no NOT IN (SELECT emp_no FROM dept_emp)
  213.  
  214. --58.获取employees中的行数据,且这些行也存在于emp_v中。注意不能使用intersect关键字。
  215. --根据题意,不能使用 INTERSECT 关键字,但由于视图 emp_v 的记录是从 employees 中导出的,因此要判断两者中相等的数据,只需要判断emp_no相等即可。
  216. -- 方法一:用 WHERE 选取二者 emp_no 相等的记录 1
  217. SELECT em.* FROM employees AS em, emp_v AS ev WHERE em.emp_no = ev.emp_no
  218.  
  219. --59.获取有奖金的员工相关信息.
  220. --给出emp_no、first_name、last_name、奖金类型btype、对应的当前薪水情况salary以及奖金金额bonus。
  221. --bonus类型btype为1其奖金为薪水salary的10%,btype为2其奖金为薪水的20%,其他类型均为薪水的30%。 当前薪水表示to_date='9999-01-01'
  222. SELECT e.emp_no, e.first_name, e.last_name, b.btype, s.salary, 
  223. (CASE b.btype 
  224.  WHEN 1 THEN s.salary * 0.1
  225.  WHEN 2 THEN s.salary * 0.2
  226.  ELSE s.salary * 0.3 END) AS bonus
  227. FROM employees AS e INNER JOIN emp_bonus AS b ON e.emp_no = b.emp_no
  228. INNER JOIN salaries AS s ON e.emp_no = s.emp_no AND s.to_date = '9999-01-01'
  229.  
  230. --60.按照salary的累计和running_total,其中running_total为前两个员工的salary累计和,其他以此类推。 具体结果如下Demo展示。
  231. --SELECT emp_no,salary, ADD(salary) AS running_total
  232. --FROM salaries
  233.  
  234. SELECT s1.emp_no, s1.salary, 
  235. (SELECT SUM(s2.salary) FROM salaries AS s2 
  236.  WHERE s2.emp_no <= s1.emp_no AND s2.to_date = '9999-01-01') AS running_total 
  237. FROM salaries AS s1 WHERE s1.to_date = '9999-01-01'
  238.  
  239. --61.对于employees表中,给出奇数行的first_name
  240. --SELECT first_name
  241. --FROM employees
  242. --WHERE
  243.  
  244. SELECT e.first_name FROM employees AS e
  245. WHERE e.first_name IN(
  246. SELECT e1.first_name
  247. FROM employees AS e1 INNER JOIN employees AS e2
  248. ON e1.first_name >= e2.first_name
  249. GROUP BY e1.first_name HAVING count(e2.first_name) % 2 = 1);

练习SQL代码的更多相关文章

  1. EntityFramework 7 如何查看执行的 SQL 代码?

    EF 其他版本:EntityFramework 如何查看执行的 SQL 代码? 在 EF7 中,并没有 Context.Database.Log 属性访问方式,但改变更加强大了,我们可以使用下面方式配 ...

  2. EntityFramework 如何查看执行的 SQL 代码?

    在 VS 调试的时候,如果我们项目中使用的是 EntityFramework,查看 SQL 执行代码就不像 ADO.NET 那样直观了,我们需要设置下,可以参考下: How can I log the ...

  3. Visual Studio Entity Framework (EF) 生成SQL 代码 性能查询

    Visual Studio Entity Framework (EF) 生成SQL 代码 性能查询     SQL 中,有SQL Server Profiler可以用来查询性能以及查看外部调用的SQL ...

  4. iOS开发数据库篇—SQL代码应用示例

    iOS开发数据库篇—SQL代码应用示例 一.使用代码的方式批量添加(导入)数据到数据库中 1.执行SQL语句在数据库中添加一条信息 插入一条数据的sql语句: 点击run执行语句之后,刷新数据 2.在 ...

  5. MySQL查询今天/昨天/本周、上周、本月、上个月份数据的sql代码

    MySQL查询本周.上周.本月.上个月份数据的sql代码 作者: 字体:[增加 减小] 类型:转载 时间:2012-11-29我要评论 MySQL查询的方式很多,下面为您介绍的MySQL查询实现的是查 ...

  6. 同样的一句SQL语句在pl/sql 代码块中count 没有数据,但是直接用SQl 执行却可以count 得到结果

    pl/sql 代码块: SELECT count(distinct t2.so_nbr) INTO v_count2 FROM KFGL_YW_STEP_qd t2 WHERE t2.partitio ...

  7. 将PL/SQL代码封装在机灵的包中

    将代码封装在机灵的包中 http://www.oracle.com/technetwork/issue-archive/2013/13-jan/o13plsql-1872456.html 绝大多数基于 ...

  8. SQL代码整理

    --SQL代码整理: create database mingzi--创建数据库go--连接符(可省略)create table biao--创建表( lieming1 int not null,-- ...

  9. oracle 11g 从 dmp 文件中导出 sql 代码 的方法.

    impdp sys/password full=y dumpfile=bg.dmp nologfile=y sqlfile=bg_dmp.sql 备注: bg.dmp 是 dmp 文件,   bg_d ...

  10. 使用PL/Scope分析PL/SQL代码

    使用PL/Scope分析你的PL/SQL代码 从11g開始Oracle引入了PL/Scope 用于编译器收集PL/SQL程序单元的全部标识符(变量名.常量名.程序名等). 收集到的信息可通过一系列静态 ...

随机推荐

  1. 雷林鹏分享:Ruby 块

    Ruby 块 您已经知道 Ruby 如何定义方法以及您如何调用方法.类似地,Ruby 有一个块的概念. 块由大量的代码组成. 您需要给块取个名称. 块中的代码总是包含在大括号 {} 内. 块总是从与其 ...

  2. 通过IIS寄宿WCF服务

    WCF全面解析一书中的例子S104,直接将Service目录部署到iis是无法得到服务相应的,需要在项目中新建一个web项目,删除掉自动生成的所有文件之后,把Service目录下的Calculator ...

  3. 20170601xlVBA正则表达式提取体检数据

    Public Sub GetFirst() GetDataFromWord "初检" End Sub Public Sub GetDataFromWord(ByVal SheetN ...

  4. 关于"架构"

    杨光辉说,在构架系统的早期可能不会更多地考虑架构,主要是在做技术选型,首先是编程语言的选择.对于编程语言选择,当前主流编程语言有很多,有面向对象语言.传统式语言等.做这个选择主要根据人员知识储备,包括 ...

  5. layui怎么通过jquery去控制一个本身已经隐藏的div让他通过点击显示出来

    $('#test_form_show').removeClass('layui-hide');

  6. mysql日期查询大全

    -- 查询昨日一整天的数据 DAY) ,'%Y-%m-%d 23:59:59') AS '昨日结束时间' -- 查询今日开始到当前时间的数据 DAY) ,'%Y-%m-%d %H:%i:%s') AS ...

  7. python-day68--模型层基础(model)

    一.ORM : object relationship mapping   对象映射关系 映射关系: 表名 <-------> 类名 字段 <-------> 属性 表记录 & ...

  8. vnc xfce tab自动补全失效的解决方法

    edit~/.config/xfce4/xfconf/xfce-perchannel-xml/xfce4-keyboard-shortcuts.xml find the line <proper ...

  9. ActiveMQ (一):安装启动及测试

    1. 预备知识 1.1 JMS JMS(Java Messaging Service)是Java平台上有关面向消息中间件(MOM)的技术规范.<百科> 1.2 JMX JMX(Java M ...

  10. forget word out a~4

    1● ana 错误,分开   2● ante   先,前面   3● anti 反对,相反       1◆ ana 2◆ ante 3◆ anti     1● dem(o) 2● pupl 3● ...