mysql准确查询语句_mysql 查询语句整理

单表查询

MySQL从数据表中查询数据最基本的语句是SELECT语句,在前面的“增删查”已经使用过:SELECT * FROM 表名,也就是查询指定数据表中的所有数据。下面将对SELECT语句进行详细介绍。

查询所有字段

语法:SELECT 字段名1,字段名2,…

FROM 表名

结果:

0e6f42c79db4d093cb7cb10c92dab133.png

注意:字段顺序可以更改则显示的结果也会作出对应的调整:

d13e20364103de394ba13aa53bd12e04.png

4.1.2  在SELECT语句中使用(‘ * ’)通配符代替所有字段

语法:SELECT * FROM 表名;

8a89313048e7f2e1e3f1c7151fc56156.png

4.1.3  查询指定的部分字段

语法:SELECT 字段名1,字段名2,… FROM 表名;

82807f37c89469e8b39be8ec9c58b2f4.png

4.2   按条件查询

4.2.1  带关系运算符的查询

语法:SELECT 字段名1,字段名2,…

FROM 表名

WHERE 条件表达式

在WHERE子句中可以使用如下关系运算符:

关系运算符

说        明

=

等于

<>

不等于

!=

不等于

<

小于

<=

小于等于

>

大于

>=

大于等于

63c64f8012fd0702ba6a7382a39f4e55.png

举例:

a11bcf93e40e43726d4aa71ad4e244fa.png

4.2.2  带 IN 关键字的查询

IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来.

语法:SELECT * | 字段名1,字段名2,…

FROM 表名

WHERE 字段名 [ NOT ]  IN (元素1,元素2,…)

f75743276d0f16a0b4261ba33efd8bad.png

注意:NOT IN 与 IN 相反,查询的是不在指定范围内的记录。

4.2.3  带 BETWEEN AND  关键字的查询

BETWEEN AND 用于判断某个字段的值是否在指定范围之内,若在,则该字段所在的记录会被查询出来,反之不会。

语法:SELECT * | { 字段名1,字段名2,… }

FROM  表名

WHERE 字段名 [ NOT ] BETWEEN  值1  AND  值2;

bf4a9df26ad5e7453b9f75d75844f02c.png

注意:NOT BETWEEN AND 表示查询指定范围外的记录。

4.2.4  空值查询

在数据表中有些值可能为空值(NULL),空值不同于0,也不同于空字符串,需要使用 IS NULL 来判断字段的值是否为空值。

语法:SELECT * | 字段名1,字段名2,…

FROM 表名

WHERE 字段名 IS [ NOT ] NULL

a9da8fe3fe14b2b2d1696f993e76fa69.png

b991790f0bf7e76af89863f292b02b4d.png

注意:IS NOT NULL 关键字用来查询字段不为空值的记录。

4.2.5  带 DISTINCT 关键字的查询

很多表中某些字段的数据存在重复的值,可以使用DISTINCT关键字来过滤重复的值,只保留一个值。

语法:SELECT DISTINCT 字段名 FROM 表名;

9247a8cf58e549bd37b3ebc71f127626.png

注意:DISTINCT 关键字还可作用于多个字段,则只有多个字段的值都完全相同时才会被认作是重复记录。

4.2.6  带 LIKE 关键字的查询

语法:SELECT * | 字段名1,字段名2,…

FROM 表名

WHERE 字段名 [ NOT ] LIKE ‘匹配字符串’;

百分号(%)通配符

匹配任意长度的字符串,包括空字符串。例如,字符串“ c% ”匹配以字符 c 开始,任意长度的字符串,如“ ct  ”,“ cut ”,“ current ”等;字符串“ c%g ”表示以字符 c 开始,以 g 结尾的字符串;字符串“ %y% ”表示包含字符“ y ”的字符串,无论“ y ”在字符串的什么位置。

119c773f3b7e12e8b9174f859b460709.png

3cb5a97c47b2f56a450ece063753d88e.png

89e6f91ebe119fe55e2beafc62f4321b.png

(2)下划线(_)通配符

下划线通配符只匹配单个字符,若要匹配多个字符,需要使用多个下划线通配符。例如,字符串“ cu_ ”匹配以字符串“ cu ”开始,长度为3的字符,如“ cut ”,“ cup ”;字符串“ c__l”匹配在“ c ”和“ l ”之间包含两个字符的字符串,如“ cool ”。需要注意的是,连续的“_”之间不能有空格,例如“M_ _QL”只能匹配“My SQL”,不能匹配“MySQL”。

a2090580556a675f6bbc46dc4e816292.png

注意:若要查询的字段值本来就含有“ % ”或者“ _ ”,则要用“ \ ”进行转义,如要查询本身含有“ % ”的字符串,命令应改为 “ %\%%”。

4.2.7  带 AND 关键字的多条件查询

在使用SELECT语句查询数据时,优势为了使查询结果更加精确,可以使用多个查询条件,如使用 AND 关键字可以连接两个或多个查询条件。

语法:SELECT * | 字段名1,字段名2,…

FROM 表名

WHERE 条件表达式1 AND 条件表达式2 [ … AND 条件表达式 n ];

2db72431ecdce199aaa5d37c57b0da23.png

4.2.8  带 OR 关键字的多条件查询

与 AND 关键字不同,OR 关键字只要满足任意一个条件就会被查询出来

语法:SELECT * | 字段名1,字段名2,…

FROM 表名

WHERE 条件表达式1 OR 条件表达式2 [ … OR 条件表达式 n ];

2c5fa9614c46e3219029448947556b46.png

4.2.9   OR 和 AND 一起使用的情况

OR 和 AND 一起使用的时候,AND 的优先级高于 OR,因此二者一起使用时,会先运算 AND 两边的表达式,再运算 OR 两边的表达式。

c0b8047ebe4a8b6475b610c6f3c1d6db.png

高级查询

聚合函数

函数名称

作用

COUNT()

返回某列的行数

SUM()

返回某列值的和

AVG()

返回某列的平均值

MAX()

返回某列的最大值

MIN()

返回某列的最小值

(1)COUNT()函数:统计记录的条数

语法:SELECT COUNT(*) FROM 表名

2dfe630d03839281f166bf403cf0960a.png

(2)SUM()函数:求出表中某个字段所有值的总和

语法:SELECT  SUM(字段名) FROM 表名;

09b91f961a7fad65751a5c1c964226e2.png

(3)AVG()函数:求出表中某个字段所有值的平均值

语法:SELECT AVG(字段名) FROM 表名;

186babd90a80e8564b997405b89e1ade.png

(4)MAX()函数:求出表中某个字段所有值的最大值

语法:SELECT MAX(字段名) FROM 表名;

e752096a13547a03868449ef79de1478.png

(5)MIN()函数:求出表中某个字段所有值的最小值

语法:SELECT MIN(字段名) FROM 表名;

1a48b4a68fc51e0fab45d9feec8efbdf.png

4.3.2  对查询结果进行排序

语法:SELECT 字段名1,字段名2,…

FROM 表名

ORDER BY 字段名1 [ ASC | DESC ],字段名2 [ ASC | DESC ]…

在该语法中指定的字段名是对查询结果进行排序的依据,ASC表示升序排列,DESC 表示降序排列,默认情况是升序排列。

4f855229d195304d213adef0c6bcedeb.png

fe998a509b7ddd7d7aca966d59859ceb.png

4.3.3  分组查询

在对表中数据进行统计的时候,可以使用GROUP BY 按某个字段或者多个字段进行分组,字段中值相同的为一组,如男生分为一组,女生分为一组。

语法:SELECT  字段名1,字段名2,…

FROM 表名

GROUP BY 字段名1,字段名2,… [ HAVING 条件表达式 ];

(1)单独使用 GROUP BY 进行分组

单独使用GROUP BY 关键字,查询的是每个分组中的一条记录

77383635ed57fdc5e98ee084eb5acd4f.png

注意:若在此2例中键入命令之后出现“#1055”错误,无法完成分组查询,是由于MySQL版本升级到了5.7,可自行百度“MySQL 1055错误”参考解决办法。

(2) GROUP BY 和聚合函数一起使用

GROUP BY 和聚合函数一起使用,可以统计出某个或者某些字段在一个分组中的最大值、最小值、平均值等。

2b7c05fd474b9ddc0e1599f99beec0fa.png

(2) GROUP BY 和 HAVING 关键字一起使用

HAVING关键字和WHERE关键字的作用相同,区别在于HAVING 关键字可以跟聚合函数,而WHERE 关键字不能。通常HAVING 关键字都和GROUP BY一起使用,用于对分组后的结果进行过滤。

0c11c6e48e729bc2d0a2bc67010128a9.png

4.3.4  使用 LIMIT 限制查询结果的数量

语法:SELECT 字段名2,字段名2,…

FROM 表名

LIMIT [ OFFSET ,] 记录数

在此语法中,LIMIT 后面可以跟两个参数,第一个参数“ OFFSET ”表示偏移量,如果偏移量为0,则从查询结果的第一条记录开始,偏移量为1则从查询结果中的第二条记录开始,以此类推。OFFSET为可选值,默认值为0,第二个参数“记录数”表示指定返回查询记录的条数。

f704ec024a10b0f4012d26086a731a09.png

454dfa4a7b3c816d33fee72ab07f82b4.png

4.4  为表和字段取别名

4.4.1 为表取别名

在进行查询操作时,如果表名很长使用起来不方便,可以为表取一个别名来代替表的名称。

语法:SELECT * FROM 表名 [ AS ] 别名;

c50585155c7125830b5db1039a30549a.png

4.4.1 为字段取别名

语法:SELECT 字段名 [ AS ] 别名 [ ,字段名 [AS] 别名,…]  FROM 表名 ;

4716491c161efd8ca5997905088ecc0a.png

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值