SELECT 数据查询
基础
显示如何使用简单的select
语句查询单个表中的数据
使用SELECT
语句从表或视图获取数据。
表由行和列组成,如电子表格。 通常,我们只希望看到子集行,列的子集或两者的组合。
SELECT语句的结果称为结果集,它是行列表,每行由相同数量的列组成。
select 语法
SELECT
column_1, column_2, ...
FROM
table_1
[INNER | LEFT |RIGHT] JOIN table_2 ON conditions
WHERE
conditions
GROUP BY column_1
HAVING group_conditions
ORDER BY column_1
LIMIT offset, length;
SELECT语句由以下列表中所述的几个子句组成:
- SELECT 之后是逗号分隔列或星号(*)的列表,表示要返回所有列。
- FROM 指定要查询数据的表或视图。
- JOIN 根据某些连接条件从其他表中获取数据。
- WHER E过滤结果集中的行。
- GROUP BY将一组行组合成小分组,并对每个小分组应用聚合函数。
- HAVING 过滤器基于GROUP BY子句定义的小分组。
- ORDER BY 指定用于排序的列的列表。
- LIMIT 限制返回行的数量。
语句中的SELECT
和FROM
语句是必须的,其他部分是可选的。
SELECT
语句允许通过在SELECT
子句中指定逗号分隔列的列表来查询表的部分数据
SELECT
lastname, firstname, jobtitle
FROM
employees;
#选出lasrname,firstname,jobtitle三列
SELECT
*
FROM
employees;
选出所有列数据。
建议显式获取数据的列,原因如下:
- 使用星号(*)可能会返回不使用的列的数据。 它在MySQL数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。
- 如果明确指定列,则结果集更可预测并且更易于管理。 想象一下,当您使用星号(*)并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。
- 使用星号(*)可能会将敏感信息暴露给未经授权的用户
格式
select 列筛选 form table where 行筛选
还有一些有用的运算符可以在WHERE子句中使用来形成复杂的条件,例如:
BETWEEN 选择在给定范围值内的值。
LIKE 匹配基于模式匹配的值。
IN 指定值是否匹配列表中的任何值。
IS NULL 检查该值是否为NULL。
SELECT 子查询
在一个查询过程中 嵌套另一个查询,子查询的结果作为外部查询的条件或者数据范围来使用。
分为 3 类:
-
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 ....);
比子查询的任意一个值大
- ex:
-
-
from 型
-
select 展示列名 from 表名 inner join (select 列名 from ...) 临时表名 on 条件;
- 其中,select的子查询所得的表 为临时表,后跟临时表名,可在条件判断中指代
-
-
exist 型
-
select 展示列 from 表名 where exists (select 列名 from 表名 where 条件);
- 将主查询的结果带入子查询进行条件判断和匹配,如果查询出结果即保留。
-
去重 DISTINCT
SELECT 语句执行简单的数据查询时,返回的是所有匹配的记录。distinct
实现查询不重复的数据
DISTINCT 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户。
SELECT DISTINCT <字段名> FROM <表名>;
# 字段名”为需要消除重复记录的字段名称,多个字段时用逗号隔开。
使用 DISTINCT
关键字时需要注意以下几点:
-
DISTINCT
关键字只能在SELECT
语句中使用。 - 在对一个或多个字段去重时,
DISTINCT
关键字必须在所有字段的最前面。 - 如果
DISTINCT
关键字后有多个字段,则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重。
指定别名 AS
1. 为表指定别名
- 当表名很长的时候 或者 执行了一些特殊的查询的时候,为方便操作,可以为表指定一个别名,用以替代原来的名称
- 语法.
-
<表名> as <别名>
- 含义:
-
<表名>
: 数据库中存储的数据表名称。 -
<别名>
: 查询的时候指定的新的名称。 -
as
: 此关键字 可以 省略,省略之后要将表名
与别名
用空格
分开
注意:表的别名不能与该数据库的其它表同名。字段的别名不能与该表的其它字段同名。在条件表达式中不能使用字段的别名,否则会出现“ERROR 1054 (42S22): Unknown column”这样的错误提示信息。
ex1:
SELECT stu.name,stu.height FROM tb_students_info AS stu;
SELECT stu.name,stu.height FROM tb_students_info stu;
2. 为字段指定别名
- 在使用 SELECT 语句查询数据时,MySQL 会显示每个 SELECT 后面指定输出的字段。有时为了显示结果更加直观,我们可以为字段指定一个别名。
- 语法:
<字段名> [AS] <别名>
- 含义:
- `<字段名>`:为数据表中字段定义的名称。
- `<字段别名>`:字段新的名称。
- `AS` 关键字可以省略,省略后需要将字段名和别名用空格隔开
注意:表别名只在执行查询时使用,并不在返回结果中显示。而字段定义别名之后,会返回给客户端显示,显示的字段为字段的别名
ex2:
SELECT name AS student_name, age AS student_age FROM tb_students_info;
SELECT name AS student_name, age student_age FROM tb_students_info;
限制查询条数 LIMIT
- LIMIT 关键字有 3 种使用方式,即
-
指定初始位置
、 不指定初始位置
-
OFFSET 组合
使用
-
(。。。。。 我之前一直不知道, 只会使用 limit 200
。。。。。)
指定初始位置
- 语法
-
LIMIT 初始位置,记录数
- 初始位置”表示从哪条记录开始显示;第一条记录的位置是 0,第二条记录的位置是 1。后面的记录依次类推。
- “记录数”表示显示记录的条数。
- LIMIT 后的两个参数必须都是正整数。
-
ex:tb_students_info 表中,使用 LIMIT 子句返回从第 4 条记录开始的行数为 5 的记录,SQL 语句和运行结果如下。
mysql> SELECT * FROM tb_students_info LIMIT 3,5;
+----+-------+---------+------+------+--------+------------+
| id | name | dept_id | age | sex | height | login_date |
+----+-------+---------+------+------+--------+------------+
| 4 | Jane | 1 | 22 | F | 162 | 2016-12-20 |
| 5 | Jim | 1 | 24 | M | 175 | 2016-01-15 |
| 6 | John | 2 | 21 | M | 172 | 2015-11-11 |
| 7 | Lily | 6 | 22 | F | 165 | 2016-02-26 |
| 8 | Susan | 4 | 23 | F | 170 | 2015-10-01 |
+----+-------+---------+------+------+--------+------------+
5 rows in set (0.00 sec)
# LIMIT之后的 3 是从第四行开始 5 是返回的行数
不指定初始位置
记录从第一条记录开始显示。显示记录的条数由 LIMIT 关键字指定。
- 语法
LIMIT 5
SELECT * FROM tb_students_info LIMIT 15;
LIMIT 和 OFFSET 组合使用
- 语法
LIMIT 记录数 OFFSET 初始位置
- 参数和 LIMIT 语法中参数含义相同,“初始位置”指定从哪条记录开始显示;“记录数”表示显示记录的条数。
mysql> SELECT * FROM tb_students_info LIMIT 5 OFFSET 3;
+----+-------+---------+------+------+--------+------------+
| id | name | dept_id | age | sex | height | login_date |
+----+-------+---------+------+------+--------+------------+
| 4 | Jane | 1 | 22 | F | 162 | 2016-12-20 |
| 5 | Jim | 1 | 24 | M | 175 | 2016-01-15 |
| 6 | John | 2 | 21 | M | 172 | 2015-11-11 |
| 7 | Lily | 6 | 22 | F | 165 | 2016-02-26 |
| 8 | Susan | 4 | 23 | F | 170 | 2015-10-01 |
+----+-------+---------+------+------+--------+------------+
# 该语句返回的是从第 4 条记录开始的之后的 5 条记录。即“LIMIT 5 OFFSET 3”意思是获取从第 4 条记录开始的后面的 5 条记录,和“LIMIT 3,5”返回的结果相同。
2021-12-22 今天先学到这里 明天继续 MySql 的查询 学习
SELECT 数据查询(二)
对查询结果排序 ORDER BY
ORDER BY 关键字主要用来将查询结果中的数据按照一定的顺序进行排序
- 语法:
-
order by <字段名> [asc|desc]
- 说明 asc 按照升序排序【默认】, desc 按照降序排序
-
- 注意:
- ORDER BY 关键字后可以跟子查询
- 当排序的字段中存在空值时,ORDER BY 会将该空值作为最小值来对待
- 当排序的字段中存在空值时,ORDER BY 会将该空值作为最小值来对待
查询数据按字母升序进行排序(A~Z),但数据的排序并不仅限于此,还可以使用 ORDER BY 中的 DESC 对查询结果进行降序排序(Z~A)。
mysql> SELECT * FROM tb_students_info ORDER BY height;
mysql> SELECT name,height FROM tb_students_info ORDER BY height,name;
mysql> SELECT name,height FROM tb_student_info ORDER BY height DESC,name ASC;
条件查询数据 WHERE
如果需要有条件的从数据表中查询数据,可以使用 WHERE 关键字来指定查询条件。
- 语法
-
WHERE conditons
- 带比较运算符和逻辑运算符的查询条件
- 带 BETWEEN AND 关键字的查询条件
- 带 IS NULL 关键字的查询条件
- 带 IN 关键字的查询条件
- 带 LIKE 关键字的查询条件
-
单条件查询
mysql> SELECT name,height FROM tb_students_info
-> WHERE height=170;
mysql> SELECT name,age FROM tb_students_info
-> WHERE age<22;
多条件查询
在 WHERE 关键词后可以有多个查询条件,这样能够使查询结果更加精确。多个查询条件时用逻辑运算符 AND(&&)、OR(||)
或 XOR
隔开。
- AND :记录 满足所有条件,才会被查询出结果
- OR : 记录 满足任意一个查询条件,才会被查询出结果
- XOR : 记录 满足其中一个条件,并且不满足另外一个条件是,才会被查询出结果
mysql> SELECT name,age,height FROM tb_students_info
-> WHERE age>21 AND height>=175;
mysql> SELECT name,age,height FROM tb_students_info
-> WHERE age>21 OR height>=175;
mysql> SELECT name,age,height FROM tb_students_info
-> WHERE age>21 XOR height>=175
OR、AND 和 XOR 可以一起使用,但是在使用时要注意运算符的优先级。
http://c.biancheng.net/view/7399.html
模糊查询 LIKE [新知识 4me]
- 语法:
-
[NOT]LIKE
- NOT :可选参数,字段中的内容与指定的字符串不匹配时满足条件。
- 字符串:指定用来匹配的字符串。“字符串”可以是一个很完整的字符串,也可以包含通配符。
-
LIKE 关键字支持百分号%
和下划线_
通配符。
带有“%”通配符的查询
“%”是 MySQL 中最常用的通配符,它能代表任何长度的字符串,字符串的长度可以为 0。
例如,a%b表示以字母 a 开头,以字母 b 结尾的任意长度的字符串。该字符串可以代表 ab、acb、accb、accrb 等字符串。
mysql> SELECT name FROM tb_students_info
-> WHERE name LIKE 'T%';
+--------+
| name |
+--------+
| Thomas |
| Tom |
+--------+
mysql> SELECT NAME FROM tb_students_info
-> WHERE NAME NOT LIKE 'T%'
+-------+
| NAME |
+-------+
| Dany |
| Green |
| Henry |
| Jane |
| Jim |
| John |
| Lily |
| Susan |
+-------+
mysql> SELECT name FROM tb_students_info
-> WHERE name LIKE '%e%';
+-------+
| name |
+-------+
| Green |
| Henry |
| Jane |
+-------+
注意:匹配的字符串必须加单引号或双引号。
带有“_”通配符的查询
“_”只能代表单个字符,字符的长度不能为 0。
例如,a_b可以代表 acb、adb、aub 等字符串。
mysql> SELECT name FROM tb_students_info
-> WHERE name LIKE '____y';
+-------+
| name |
+-------+
| Henry |
+-------+
LIKE 区分大小写(默认不区分)
默认情况下,LIKE 关键字匹配字符的时候是 不 区分大小写的。如果需要 可以加入BINARY
关键字
mysql> SELECT name FROM tb_students_info WHERE name LIKE 't%';
mysql> SELECT name FROM tb_students_info WHERE name LIKE BINARY 't%';
使用通配符的注意事项和技巧
- 注意事项:
- 注意大小写。MySQL 默认是不区分大小写的。如果区分大小写,像“Tom”这样的数据就不能被“t%”所匹配到。
- 注意尾部的空格 尾部空格会干扰通配符的匹配。例如,“T% ”就不能匹配到“Tom”。
- 注意NULL。”%”通配符可以到匹配任意字符,但是不能匹配 NULL。也就是说 “%”匹配不到 tb_students_info 数据表中值为 NULL 的记录。
- 使用技巧:
- 不要过度使用通配符,如果其它操作符能达到相同的目的,应该使用其它操作符。因为 MySQL 对通配符的处理一般会比其他操作符花费更长的时间。
- 在确定使用通配符后,除非绝对有必要,否则不要把它们用在字符串的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。
- 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。
拓展
如果查询内容中包含通配符,可以使用“\”转义符。
mysql> SELECT NAME FROM test.`tb_students_info` WHERE NAME LIKE '%\%';
2021-12-23 今天先学到这里 明天继续 MySql 的查询 学习