简单讲解MySQL的高级语句
(一)按关键字排序
1.使用ORDER BY语句来实现排序
2.排序可针对一个或多个字段
3.ASC:升序,默认排序方式
4.DESC:降序
6.ORDER BY的语法结构:select column1,column2… from 库名 order by column1,column2,… asc|desc;
升序:
降序:
加入条件排序:
多条件排序:
(二)对结果进行分组
1.使用GROUP BY语句来实现分组
2.通常结合聚会函数一起使用
3.可以按一个或多个字段对结果进行分组
4.GROUP BY的语法结构:
select column_name,aggregate_function(column_name) from table_name where column_name operator value GROUP BY column_name;
(三)限制结果条目
1.只返回SELECT查询结果的第一行或前几行
2.使用LIMIT语句限制条目
3.LIMIT语法结构:select column1,column2,… from table_name [offset,] number;
第一个数字:位置偏移量是从零开始,第二个数字:返回记录行的最大数目
第三到第五
(四)设置别名
1.使用AS语句设置别名,关键字AS可省略
2.设置别名时,保证不能与库中其他表或字段名称冲突
3.别名的语法结构:select column_name AS alias_name from table_name;
select column_name(s) from table_name AS alias_name;
as复制:
as统计:
as别名:
(五)通配符
1.用于替换字符串中的部分字符
2.通常配合LIKE一起使用,并协同WHERE完成查询
3.常用通配符
%表示零个,一个或多个
_表示单个字符
(六)子查询
1.也称作内查询或者嵌套查询
2.先于主查询被执行,其结果将作为外层主查询的条件
3.在增删改查中都可以使用子查询
4.支持多层嵌套
5.IN语句是用来判断某个值是否在给定的结果集中
(七)NULL值
1.表示缺失的值
2.与数字0或者空白(spaces)是不同的
3.使用IS NULL或IS NOT NULL进行判断
4.NULL值和空值的区别:(1)空值长度为0,不占空间;
(2)NULL值的长度为NULL,占用空间
(3)IS NULL无法判断空值
(4)空值使用"=“或者”<>"来处理
(5)COUNT () 计算时,NULL会忽略,空值会加入计算
(八)正则表达式
1.根据指定的匹配模式匹配记录中符合要求的特殊字符
2.使用REGEXP关键字指定匹配模式
(九)运算符
(1)算数运算符
(1.1)用于对记录中的字段值进行运算
MySQL 的运算符共有四种,分别是:算术运算符、比较运算符、逻辑运算符和位运算符
(1.2)以select命令来实现最基础的加减乘除运算,具体操作如下所示:
(1.3)整数相除,出来的结果是浮点型的。
在除法运算和求余数运算中,除数不能为 0,若除数是 0,返回的结果则为 NULL。
需要注意的是,如果有多个运算符,按照先乘除后加减的优先级进行运算
(1.4)某些字符串类型的字段存储的数字型字符串,这些字段在进行算术运算时将会被自动转换为数字的值。如果字符串的开始部分是数字,在转换时将被转换为这个数字。如果是既包含字符又包含数字得的混合字符串,无法转换为数字时,将被转换为 0。
(2) 比较运算符
(2-1) 等于运算符
用来判断数字、字符串和表达式是否相等的,如果相等则返回 1,如果不相等则返回 0。其中字符的比较是根据 ASCII 码来判断的。
ASCII码表转换:
0-48,1-49,…9-57
A-65,B-66
a-97,b-98
比较规则:
如果两者都是整数,则按照整数值进行比较。
如果一个整数一个字符串,则会自动将字符串转换为数字,再进行比较。
如果两者都是字符串,则按照字符串进行比较。
如果两者中至少有一个值是 NULL,则比较的结果是 NULL
(2-2) 不等于运算符
不等于号有两种写法,分别是<>或者!=,用于针对数字、字符串和表达式不相等的比较。如果不相等则返回 1,如果相等则返回 0。
需要注意的是不等于运算符不能用于判断 NULL。
(2-3) 大于、大于等于、小于、小于等于运算符
注意:都不能用于判断NULL。
(2-4) IS NULL、IS NOT NULL
IS NULL 判断一个值是否为 NULL,如果为 NULL 返回 1,否则返回 0。
IS NOT NULL 判断一个值是否不为 NULL,如果不为 NULL 返回 1,否则返回 0。
(2-5) between and
用于判断一个值是否落在某两个值之间
例如,判断某数字是否在另外两个数字之间,也可以判断某英文字母是否在另外两个字母之间
(2-6) least、greatest
LEAST:当有两个或者多个参数时,返回其中的最小值。如果其中一个值为 NULL,则返回结果就为 NULL。
GREATEST:当有两个或者多个参数时,返回其中的最大值。如果其中一个值为 NULL, 则返回结果就为 NULL。
(2-7) in、not in
IN 判断一个值是否在对应的列表中,如果是返回 1,否则返回 0。
NOT IN 判断一个值是否不在对应的列表中,如果不是返回 1,否则返回 0。
(2-8) like、not like
LIKE 用来匹配字符串,如果匹配成功则返回 1,反之返回 0;NOT LIKE 正好跟 LIKE 相反。
LIKE 支持两种通配符:’%’ 用于匹配任意数目的字符,而’_’只能匹配一个字符。
(3)逻辑运算符
(1)逻辑非
逻辑非将跟在它后面的逻辑测试取反,把真变为假,把假变为真。
如果 NOT 后面的操作数为 0 时,所得值为 1;如果操作数为非 0 时,所得值为 0;如果操作数为 NULL 时,所得值为 NULL。
注意:非0值都是1
(2)逻辑与
如果所有值都是真返回 1,否则返回 0。
(3)逻辑或(最好用or)
逻辑或表示包含的操作数,任意一个为非零值并且不是 NULL 值时,返回 1,否则返回0。
运算总结:
and运算,只要碰到0就是0,(非0和null是null)
or运算,只要碰到非0值就是1,(0和null是null)
异或运算,只要碰到null都是null
(四)位运算符
(十)连接查询
MySQL的连接查询,通常都是将来自两个或多个表的行结合起来,基于这些表之间的共同字段,进行数据的拼接。首先,要确定一个主表作为结果集,然后将其他表的行有选择性的连接到选定的主表结果集上。使用较多的连接查询包括:内连接,左连接和右连接。
外连接:分为左连接和右连接。
左外连接就是以左表为准,去匹配右表,左表有多少条数据,结果就是多少条数据。左表有的数据正常显示,右表没有的数据就用NULL显示。