mysql 怎么反选_mysql基础操作

4.1  简单查询

4.1.1  查询所有字段

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

FROM 表名

dd6af5ec9c3d4122d231f2c74015a5ec.png

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

语法:SELECT * FROM 表名;

f7f1fdad71e92db8bf9836b383899540.png

4.1.3  查询指定的部分字段

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

7b1a518195dec02598f4f322907c40b8.png

4.2   按条件查询

4.2.1  带关系运算符的查询

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

FROM表名

WHERE 条件表达式

b463c980023c79913bde2b339e9e1c9b.png

4.2.2  带 IN 关键字的查询

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

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

FROM 表名

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

f547e1f2500fe1f72d93b33108a9281d.png

4.2.3  带 BETWEEN AND  关键字的查询

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

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

FROM  表名

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

67a9948fb525f55715089b32aefa13c6.png

4.2.4  空值查询

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

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

FROM 表名

WHERE 字段名IS [ NOT ] NULL

c92dc9e5c4e91998ff9ebdc77a504945.png

4.2.5  带DISTINCT关键字的查询

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

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

5d6ac467be41e5bffbcf82472b6154c0.png

4.2.6  带 LIKE 关键字的查询

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

FROM 表名

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

(1)百分号(%)通配符

92e2059f2b81f6ce8ae9a52c612a48ad.png

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

feb6f469299053927ba361cbe2121505.png

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

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

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

FROM 表名

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

3e895e2508d877ce859c369d0e31ae2e.png

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

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

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

FROM 表名

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

ca978979fd3b06b42ccc6a476ddac723.png

4.2.9   OR 和AND一起使用的情况

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

1d7ba928e3ee3566089188054e9035bb.png

4.3  高级查询

4.3.1  聚合函数

函数名称

作用

COUNT()

返回某列的行数

SUM()

返回某列值的和

AVG()

返回某列的平均值

MAX()

返回某列的最大值

MIN()

返回某列的最小值

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

c85ce478ec38fcdc6c73d09cd3aebe9a.png

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

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

f8023d118257f4a87ad6fdc7b61edfa0.png

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

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

80d620732cfe1e78e0c21ca897f80e4d.png

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

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

35c165e33f23bcfb1c6a81b83a2a8ac2.png

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

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

70952956986bb9bb51c360b63841a2d5.png

4.3.2  对查询结果进行排序

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

FROM 表名

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

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

5ab2a46314b5cfcb44d4303faa83af4e.png

aa056cfe195e1dbc0b42ddc4f6212064.png

4.3.3  分组查询

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

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

FROM 表名

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

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

ca70fc894a1c95844c326149e2354442.png

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

03bb76a1d24a6733b91f38a5e92b2e2f.png

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

b5ae60eb489b46879e37f2359057d31a.png

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

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

FROM 表名

LIMIT [ OFFSET ,] 记录数

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

3d41ae2b6e475a4f0a6160f4eadc31d3.png

9709fd097dfbdbd27190e0a39c93e117.png

4.4  为表和字段取别名

4.4.1 为表取别名

325fd2e80148b441930303e0fe11f80b.png

4.4.1 为字段取别名

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

120a8a734559f7155b0c9c8d34ff6035.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值