子查问
某些状况下,当进行一个查问时,须要的条件或数据要用另外一个 select 语句的后果,这个时候,就要用到子查问。
例如:
为了给主查问(内部查问)提供数据而首先执行的查问(外部查问)被叫做子查问。
个别依据子查问的嵌入地位分为,where 型子查问,from 型子查问,exists 型子查问。
1、where 型子查问
where 型子查问即把内层 sql 语句查问的后果作为外层 sql 查问的条件.
子查问要蕴含在括号内。
倡议将子查问放在比拟条件的右侧。
单行操作符对应单行子查问,多行操作符对应多行子查问。
单行操作符 左边子查问必须返回的是单个值,单行比拟运算符(=,>,>=,<,<=,<>)
多行操作符 左边子查问能够返回多行,但必须是单列,ALL, ANY,IN 其中,ALL 和 ANY 运算符必须与单行比拟运算符(=,>,>=,<,<=,<>)联合应用
IN:等于任何一个
ALL:和子查问返回的所有值比拟。例如:sal>ALL(1,2,3) 等价于 sal>1 && sal>2 && sal>3,即大于所有。
ANY:和子查问返回的任意一个值比拟。例如:sal>ANY(1,2,3)等价于 sal>1 or sal>2 or sal>3,即大于任意一个就能够。
EXISTS:判断子查问是否有返回后果(不关怀具体行数和内容),如果返回则为 TRUE,否则为 FALSE。
子查问
where 型子查问
查问比“孙红雷”的工资高的员工编号
SELECT * FROM t_salary
WHERE basic_salary > (SELECT basic_salary FROM t_employee INNER JOIN t_salary ON t_employee.eid=t_salary.eid WHERE t_employee.ename=’ 孙红雷 ’);
查问和孙红雷,李晨在同一个部门的员工
SELECT * FROM t_employee
WHERE dept_id IN(SELECT dept_id FROM t_employee WHERE ename=’ 孙红雷 ’ OR ename = ‘ 李晨 ’);
SELECT * FROM t_employee
WHERE dept_id = ANY(SELECT dept_id FROM t_employee WHERE ename=’ 孙红雷 ’ OR ename = ‘ 李晨 ’);
查问全公司工资最高的员工编号,基本工资
SELECT eid,basic_salary FROM t_salary
WHERE basic_salary = (SELECT MAX(basic_salary) FROM t_salary);
SELECT eid,basic_salary FROM t_salary
WHERE basic_salary >= ALL(SELECT basic_salary FROM t_salary);
2、from 型子查问
from 型子查问即把内层 sql 语句查问的后果作为长期表供外层 sql 语句再次查问.
from 型
找出比部门平均工资高的员工编号,基本工资
SELECT t_employee.eid,basic_salary
FROM t_salary INNER JOIN t_employee INNER JOIN (
SELECT emp.dept_id AS did,AVG(s.basic_salary) AS avg_salary
FROM t_employee AS emp,t_salary AS s
WHERE emp.eid = s.eid
GROUP BY emp.dept_id) AS temp
ON t_salary.eid = t_employee.eid AND t_employee.dept_id = temp.did
WHERE t_salary.basic_salary > temp.avg_salary;
3、exists 型子查问
exists 型
查问部门信息,该部门必须有员工
SELECT * FROM t_department
WHERE EXISTS (SELECT * FROM t_employee WHERE t_employee.dept_id = t_department.did);
4、复制表子查问(理解)
1)复制表
(1)拷贝表构造
CREATE TABLE newadmin LIKE admin;
(2)拷贝表构造和数据(但束缚与索引除外)
CREATE TABLE newadmin AS (SELECT * FROM admin) ;
(3)拷贝表构造 + 数据
CREATE TABLE newadmin LIKE admin;
INSERT INTO newadmin SELECT * FROM admin;
(4)跨数据库拷贝表
CREATE TABLE newadmin LIKE shop.admin;
CREATE TABLE newshop.newadmin LIKE shop.admin;
(5)拷贝一个表中其中的一些字段(指定新名),其中一些数据
CREATE TABLE newadmin AS
(
SELECT id, username AS uname, password AS pass FROM admin WHERE id<10
) ;
(6)在创立表的同时定义表中的字段信息。
create table tt
(
eid int primary key auto_increment
)
as
(
select employee_id as eid,first_name,last_name,email from employees
);
2)复制数据
在 INSERT 语句中退出子查问。
不用书写 VALUES 子句。
子查问中的值列表应与 INSERT 子句中的列名对应。
INSERT INTO emp2
SELECT * FROM employees WHERE department_id = 90;
或
INSERT INTO sales_reps(id, name, salary, commission_pct)
SELECT employee_id, last_name, salary, commission_pct
FROM employees
WHERE job_id LIKE ‘%REP%’;
关键词:大数据培训