(十三)MySQL语法-子查询


#进阶7:子查询
    含义:出现在其他语句中的select语句,称为子查询或者内查询
     外部的查询语句,成为主查询或者外查询

分类:
按照子查询出现的位置:
    select后面:
      仅仅支持标量子查询
    from后面:
      支持表子查询
    where或者having后面;
      标量子查询
      列子查询
      行子查询
    EXISTS后面(相关子查询)
      表子查询


按照结果集的行列数不同:
    标量子查询(结果集中只有一行一列)
    列子查询(结果集中只有一列多行)
    行子查询(结果集中有一行多列)
    表子查询(结果集中一般为多行多列)

#一、where或者having后面
    1. 标量子查询(单行子查询)
    2. 列子查询(多行子查询)
    3. 行子查询(多行子查询)
特点:
  小1:子查询放在小括号内
  小2;子查询一般放在条件的右侧
  小3:标量子查询。一般搭配着单行操作符使用
      > < >= <= = <>
列子查询,一般搭配着多行操作符使用
      in any/some all

 


#案例1:查询谁的工资比Abel的高
  select * from employees where salary >(
    select salary from employees where last_name ='Abel'
  );

#案例2:查询公司工资最少的员工的last_name job_id 和salary
  select last_name ,job_id ,salary from employees where salary=(
    select min(salary) from employees
  );


#案例4:查询最低工资大于50号部门的最低工资的部门id 和其最低工资
步骤1:先去查询50号部门员工的最低工资
select min(salary) from employees where department_id='50'
步骤3:查询每个部门的最低工资
select department_id,min(salary) from employees GROUP BY department_id;
步骤3:查询最低工资大于50号部门的最低工资的部门id 和其最低工资
select department_id,min(salary) from employees where 1=1 GROUP BY department_id
HAVING min(salary)>(select min(salary) from employees where department_id='50')

2.列子查询(多行子查询)
案例1:返回location_id是1400或者1700的部门中的所有员工的姓名
desc employees; select count(1) from employees
select last_name from employees where department_id in(
  SELECT DISTINCT department_id from locations where location_id in('1400','1700')
);
或者
select last_name from employees where department_id =any(
  SELECT DISTINCT department_id from locations where location_id in('1400','1700')
);

3.案例3:查询工种比IT_PROG任意工资少的其他工种的员工姓名,工资,工号,工种编码
select last_name,salary,employee_id,job_id from employees where salary <any(
  select DISTINCT salary from employees where job_id='IT_PROG'
) and job_id<>'IT_PROG';--76 注意:any和some的作用是一样的

或者:
select last_name,salary,employee_id,job_id from employees where salary <(
  select max(salary) from employees where job_id='IT_PROG'
) and job_id<>'IT_PROG';--76  

3.案例4:查询工种比IT_PROG工种所有员工的工资都低的其他工种的员工姓名,工资,工号,工种编码
select last_name,salary,employee_id,job_id from employees where salary <all(
  select DISTINCT salary from employees where job_id='IT_PROG'
) and job_id<>'IT_PROG';--44

或者:
select last_name,salary,employee_id,job_id from employees where salary <(
  select min(salary) from employees where job_id='IT_PROG'
) and job_id<>'IT_PROG';--44

3.行子查询
案例:查询员工编号最小并且工资最高的员工信息
步骤1;查询最小员工编号
select min(employee_id) FROM employees;
步骤2:查询最高工资
select max(salary) from employees;
步骤3:总体查询
select * from employees where employee_id=(select min(employee_id) FROM employees) and salary=(select max(salary) from employees)
换一种神奇的写法,行子查询
select * from employees where (employee_id,salary)=(select min(employee_id),max(salary) FROM employees)--同样能够查询出来结果

posted on 2020-02-19 23:23  ~码铃薯~  阅读(218)  评论(0编辑  收藏  举报

导航