mysql汇总怎么查询 mysql怎么查询全部数据( 二 )


IS NULL 检查该值是否为NULL 。
## SELECT 子查询
在一个查询过程中 嵌套另一个查询,子查询的结果作为外部查询的条件或者数据范围来使用 。
分为 3 类:
1.where 型
-`select展示列名 from 表名 where 列名 运算符[in...] (select 对应列名 from ...)`
-这个列名 和 对应列名 应该做到类型相同
-如果不加入运算符 也可使用IN 这些类似的符号-`select 展示列名 from 表名 where 列名 in (select 对应列名 from ...)`
-ex:
`select 展示列名 from 表名 where 列名 ALL(select 对应列名 from ....)`;
比子查询的值都大
`select 展示列名 from 表名 where 列名 ANY(select 对应列名 from ....);`
比子查询的任意一个值大
2.from 型
-`select 展示列名 from 表名 inner join (select 列名 from ...) 临时表名 on 条件;`
-其中,select的子查询所得的表 为临时表,后跟临时表名,可在条件判断中指代
3.exist 型
-`select 展示列 from 表名 where exists (select 列名 from 表名 where 条件);`
-将主查询的结果带入子查询进行条件判断和匹配,如果查询出结果即保留 。
## 去重 DISTINCT
SELECT 语句执行简单的数据查询时,返回的是所有匹配的记录 。`distinct` 实现查询不重复的数据
**DISTINCT 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户 。**
使用 `DISTINCT` 关键字时需要注意以下几点:
-`DISTINCT` 关键字只能在 `SELECT` 语句中使用 。
-在对一个或多个字段去重时,`DISTINCT` 关键字必须在所有字段的最前面 。
-如果 `DISTINCT` 关键字后有多个字段 , 则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重 。
## 指定别名 AS
### 1. 为表指定别名
1.当表名很长的时候 或者 执行了一些特殊的查询的时候,为方便操作,可以为表指定一个别名,用以替代原来的名称
2.语法.
3.`表名 as 别名`-含义:-`表名` : 数据库中存储的数据表名称 。
-`别名` : 查询的时候指定的新的名称 。
-`as` : 此关键字 可以 省略 , 省略之后要将 `表名`与`别名`用 `空格` 分开
***注意:表的别名不能与该数据库的其它表同名 。字段的别名不能与该表的其它字段同名 。在条件表达式中不能使用字段的别名,否则会出现“ERROR 1054 (42S22): Unknown column”这样的错误提示信息 。***
***ex1:
***
### 2. 为字段指定别名
1.在使用 SELECT 语句查询数据时 , MySQL 会显示每个 SELECT 后面指定输出的字段 。有时为了显示结果更加直观,我们可以为字段指定一个别名 。
2.语法:
3.`字段名 [AS] 别名`
-含义:
-`字段名`:为数据表中字段定义的名称 。
-`字段别名`:字段新的名称 。
-`AS` 关键字可以省略,省略后需要将字段名和别名用空格隔开
***注意:表别名只在执行查询时使用,并不在返回结果中显示 。而字段定义别名之后,会返回给客户端显示,显示的字段为字段的别名******
ex2:
***
## 限制查询条数 LIMIT
1.LIMIT 关键字有 3 种使用方式,即
-`指定初始位置`、
-`不指定初始位置`
-`OFFSET 组合`使用
( 。。。。。我之前一直不知道, 只会使用 `limit 200` 。。。。。)
### 指定初始位置
1.语法
-`LIMIT 初始位置,记录数`
-初始位置”表示从哪条记录开始显示;第一条记录的位置是 0,第二条记录的位置是 1 。后面的记录依次类推 。
-“记录数”表示显示记录的条数 。

推荐阅读