MySQL笔记(三)——DQL语言查询

SQL99语法

1、内连接

 语法:
  select 查询列表
  from 表1 别名
  【inner】 join 表2 别名 on 连接条件
  where 筛选条件
  group by 分组列表
  having 分组后的筛选
  order by 排序列表
  limit 子句;

  特点: 1、表的顺序可以调换
     2、内连接的结果=多表的交集
     3、n表连接至少需要n-1个连接条件

  分类:等值连接、非等值连接、自连接

2、外连接

 语法:
  select 查询列表
  from 表1 别名
  left|right\full【outer】 join 表2 别名 on 连接条件
  where 筛选条件
  group by 分组列表
  having 分组后的筛选
  order by 排序列表
  limit 子句;

  特点: 1、查询的结果=主表中所有的行,如果从表和它匹配的将显示匹配行,如果从表没有匹配的则显示null
   2、left join 左边的就是主表,right join 右边的就是主表,full join 两边的都是主表
   3、一般用于查询除了交集部分剩余的不匹配的行

3、交叉连接

 语法:
  select 查询列表
  from 表
  cross join 表2 别名;

 特点:类似于笛卡尔乘积


子查询

1、子查询含义

  嵌套在其他语句内部的select语句称为子查询或内查询;
  外面的语句可以是insert、update、delete、select等,一般select作为外面语句较多;
  外面如果为select语句,则此语句称为外查询或主查询。

2、分类

2.1、按出现位置

 select后面:仅仅支持标量子查询
 from后面:表子查询
 where或having后面:标量子查询、列子查询、行子查询
 exists后面:标量子查询、列子查询、行子查询、表子查询(放谁都行)

2.2、按结果集的行列

  标量子查询(单行子查询):结果集为一行一列
 列子查询(多行子查询):结果集为多行一列
 行子查询:结果集为多行多列
 表子查询:结果集为多行多列

3、示例:

 where或having后面

3.1、标量子查询

 案例:查询最低工资单额员工姓名和工资

 ① 最低工资
  select min(salary) from employees;

 ② 查询员工的姓名和工资,要求工资=①
  select last_name,salary
  from employees
  where salary = (
  select min(salary) from employees
  );

3.2、列子查询

 案例: 查询所有是领导的员工姓名
  ① 查询所有员工的 manager_id
  select manager_id from employees;

 ②查询姓名,employee_id属于①列表中的一个
  select last_name
  from employees
  where employee_id in(
  select manager_id from employees
  );

分页查询

1、分页查询应用场景

  当要查询的条目数太多,一页显示不全

2、语法:

select 列表
from 表
limit 【offset,】size;

注意:
    offset代表得到是其实的条目索引,默认从0卡死
    size代表的是显示的条目数

公式:
    假如要显示的页数为page,每一页条目数为size
        select 列表
        from 表
        limit (page-1)*size,size;

联合查询

1、含义

union:合并、联合,将多次查询结果合并成一个结果

2、语法:

查询语句1
union 【all】
查询语句2
union 【all】
...

3、意义

  1、将一条比较复杂的查询语句拆分成多条语句
  2、适用于查询多个表的时候,查询的列基本是一致

4、特点

  1、要求多条查询语句的查询列数必须一致
  2、要求多条查询语句的查询的各列类型、顺序最好一致
  3、union去重,union all包含重复项

查询总结

  select 查询列表
  from 表1 别名
  连接类型 join 表2
  on 连接条件
  where 分组前筛选
  group by 分组列表
  having 分组后筛选
  order by 排序列表
  limit 起始条目索引,条目数;

猜你喜欢

转载自blog.csdn.net/weixin_45032666/article/details/108290636
今日推荐