MySQL高阶语句(二)

本文详细介绍了MySQL中的正则表达式使用,包括^、$、.、*、+等特殊字符的含义及用法,还列举了各种匹配模式的例子。此外,还阐述了MySQL的算术、比较、逻辑和位运算符,详细解析了它们的功能和用法,如加减乘除、等于、大于、小于、ISNULL、BETWEEN AND、LIKE等,并讨论了运算符的优先级问题。
摘要由CSDN通过智能技术生成

目录

一、正则表达式

二、运算符

1.算术运算符

2.比较运算符

3.逻辑运算符(布尔值) 

4.位运算符


一、正则表达式

MySQL 正则表达式通常是在检索数据库记录的时候,根据指定的匹配模式匹配记录中 符合要求的特殊字符串。MySQL 的正则表达式使用 REGEXP 这个关键字来指定正则表达 式的匹配模式,REGEXP 操作符所支持的匹配模式如表所示。

regexp的使用方式

^匹配文本的开始字符
$匹配文本的结束字符
.匹配任何单个字符
*匹配零个或多个在它前面的字符
+匹配前面的字符 1 次或多次
字符串匹配包含指定的字符串
p1|p2匹配 p1 或 p2
[…]匹配字符集合中的任意一个字符
[^…]匹配不在括号中的任何字符
{n}匹配前面的字符串 n 次
{n,m}匹配前面的字符串至少 n 次,至多 m 次

查询以li开头的学生信息

查询名字中包含an的学生信息

查询名字是hanm开头,i结尾,中间不知道是一个什么字符的学生信息

查询名字中包含an或者zh的学生信息

查询名字以s-x开头的学生信息

必须要有的部分是'an' 而'g'可有可无

查询名字不是caicai的学生信息 

查询学生名字不以czx各字母开头的学生信息 

二、运算符

MySQL 的运算符用于对记录中的字段值进行运算。MySQL的运算符共有四种,分别是算术运算符、比较运算符、逻辑运算符和位运算符。

1.算术运算符

运算符	描述
+		加法
-		减法
*		乘法
/		除法
%		取余
#在除法运算和求余数运算中,除数不能为 0,若除数是 0,返回的结果则为 NULL。
#需要注意的是,如果有多个运算符,按照先乘除后加减的优先级进行运算,相同优先级的运算符没有先后顺序。

2.比较运算符

比较运算符是查询数据记录时经常使用的一类运算符。通过使用比较运算符可以判断出 表中有哪些记录是符合条件的,如果比较的结果(以布尔值的方式进行返回判断)为真则返回 1,如果为假则返回 0,比较的结果如果不确定则返回NULL。其中字符串在进行比较的时候默认是不区分大小写的,如果要区分大小写可以通过binary关键字来实现。

运算符			描述
=				等于
>				大于
<				小于
>=				大于等于
<=				小于等于
!=或<>			不等于
is null			判断一个值是否为 NULL
IS NOT NULL		判断一个值是否不为 NULL
BETWEEN AND		两者之间
IN				在集合中
LIKE			通配符匹配
GREATEST		两个或多个参数时返回最大值
LEAST			两个或多个参数时返回最小值
REGEXP			正则表达式
如果相等则返回 1(true),如果不相等则返回 0(flase)。如果比较的两者有一个值是 NULL,则比较的结果就是NULL。

等号(=)运算符

① 如果两者都是整数,则按照整数值进行比较。
②如果一个整数一个字符串,则会自动将字符串转换为数字,再进行比较。(在程序中,一般是不会吧这两者进行相比较的)。
③ 如果两者都是字符串,则按照字符串进行比较。
④ 如果两者中至少有一个值是 NULL,则比较的结果是 NULL。

不等于(<>,!=) 运算符

不等于号有两种写法,分别是<>或者!=,用于针对数字、字符串和表达式不相等的比较。 如果不相等则返回 1,如果相等则返回 0,这点正好跟等于的返回值相反。需要注意的是不等于运算符不能用于判断 NULL。

① 大于(>)运算符用来判断左侧的操作数是否大于右侧的操作数,若大于返回 1,否则返回0,同样不能用于判断NULL。
② 小于(<)运算符用来判断左侧的操作数是否小于右侧的操作数,若小于返回 1,否则返回0,同样不能用于判断NULL。
③ 大于等于(>=)判断左侧的操作数是否大于等于右侧的操作数,若大于等于返回 1,否则返回 0,不能用于判断NULL。
④ 小于等于(<=)判断左侧的操作数是否小于等于右侧的操作数,若小于等于返回 1,否则返回 0,不能用于判断 NULL。

判断一个值为/不为null ( IS NULL、IS NOT NULL )

IS NULL判断一个值是否为 NULL,如果为NULL返回1,否则返回0。
IS NOT NOLL判断一个值是否不为 NULL,如果不为NULL返回1,否则返回 0。 

BETWEEN AND 运算符

比较运算通常用于判断一个值是否落在某两个值之间。例如,判断某数字是否在另外两个数字之间,也可以判断某英文字母是否在另外两个字母之间,具体操作,条件符合返回1,否则返回0。

least 和greatest(取最小值、取最大值)

LEAST:当有两个或者多个参数时,返回其中的最小值。如果其中一个值为 NULL,则返回结果就为 NULL。
GREATEST:当有两个或者多个参数时,返回其中的最大值。如果其中一个值为NULL, 则返回结果就为 NULL。

IN 判断一个值是否在对应的列表中,如果是返回 1,否则返回 0。
NOT IN 判断一个值是否不在对应的列表中,如果不是返回 1,否则返回 0 。

LIKE 用来匹配字符串,如果匹配成功则返回 1,反之返回 0。
NOT LIKE 正好跟 LIKE 相反,如果没有匹配成功则返回 1,反之返回 0。 

3.逻辑运算符(布尔值) 

逻辑运算符又被称为布尔运算符,通常用来判断表达式的真假,如果为真返回 1,否则 返回 0,真和假也可以用 TRUE 和 FALSE 表示。MySQL 中支持使用的逻辑运算符有四种, 具体如表所示。

运算符			描述
not 或 !		逻辑非
and 或 &&		逻辑与
or 				逻辑或
xor				逻辑异或

逻辑非

逻辑运算符中最简单的运算符就是逻辑非,逻辑非使用 NOT 或!表示。逻辑非将跟在它后面的逻辑测试取反,把真变为假,把假变为真。如果 NOT 后面的操作数为 0 时,所得值为 1;如果操作数为非 0 时,所得值为 0;如果操作数为 NULL 时,所得值为 NULL。

逻辑与(and)

当所有的操作数都为非0值且不为null时,返回值为1,否则为0

null与0比较特殊,逻辑与使用 AND 或者&&表示

and 和&& 的作用相同
1 and -1 没有0 或 null,所以返回值为1
1 and 0 中由有0,所以返回值为0
1 and null 有Null ,所以返回值为null
null and 0 返回值为0 

逻辑或(or)

逻辑或通常使用 OR ,逻辑或表示包含的操作数,任意一个为非零值并且不是 NULL 值时,返回 1,否则返回 0。
当有一个操作数为null时,如果另一个操作数为非0值,则返回值为1,否则为null。如两个操作数均为null,则返回值为null。

1 OR -1 OR 0含有0,但同时包含有非0的值1和-1,所以返回结果为1;
1 OR 2 中没有操作数0,所以返回结果为1;
1 OR NULL虽然有 NULL,但是有操作数1,所以返回结果为1;
0 OR NULL中没有非0值,并且有NULL,所以返回值为NULL;
NULL OR NULL中只有NULL,所以返回值为NULL。

逻辑异或(xor)

两个非 NULL 值的操作数,如果两者都是 0 或者都是非 0,则返回 0;
如果一个为 0, 另一个为非 0,则返回结果为 1;
当任意一个值为 NULL 时,返回值为 NULL。

4.位运算符

位运算符实际上是对二进制数进行计算的运算符。MySQL 内位运算会先将操作数变成二进制格式(1010 1111),然后进行位运算,最后在将计算结果从二进制变回到十进制格式,方便用户查看。MySQL 支持 6 种位运算符,具体如表所示。

位运算符	描述
&			按位与
|			按位或
~			按位取反
^			按位异或
<<			按位左移
>>			按位右移

按位与运算(&),是对应的二进制位都是1的,它们的运算结果为 1,否则为 0,所以 10 & 15 的结果为 10。
按位或运算(|),是对应的二进制位有一个或两个为 1 的,运算结果为 1,否则为 0, 所以 10 | 15 的结果为 15。
按位异或运算(^),是对应的二进制位不相同时,运算结果 1,否则为 0,所以 10 ^ 15 的结果为 5。
按位取反(~),是对应的二进制数逐位反转,即 1 取反后变为 0, 0 取反后变为 1。数字 1 的二进制是 0001,取反后变为 1110, 数字 5 的二进制是 0101,将 1110 和 0101
进行求与操作,其结果是二进制的 0100,转换为十进制就是 4 。

以上不管哪种运算符,在使用过程中都有优先级问题。运算符的优先级决定了不同的运 算符在计算过程中的先后顺序。级别高的运算符会先进行计算,如果运算符的级别相同, MySQL 会按照顺序从左到右依次进行计算,优先级如下表所示:

优先级	运算符
1		!
2		~
3		^
4		*、/、%
5		+,-
6		>>,<<
7		&
8		|
9		=,<=>,>=,>,<=,<,<>,!=,IS,LIKE,REGEXP,IN
10		BETWEEN,CASE,WHEN,THEN,ELSE
11		NOT
12		&&,AND
13		||,OR,XOR
14		:=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL 提供了一些高阶的查询语句用法,可以帮助我们更灵活、高效地进行数据查询。以下是一些常用的高阶用法: 1. 子查询: 子查询是将一个查询嵌套在另一个查询中的查询结构。它可以用作 `SELECT` 语句中的列、`FROM` 子句中的表、`WHERE` 子句中的条件等。 示例: ```sql SELECT column_name FROM table_name WHERE column_name IN (SELECT column_name FROM another_table WHERE condition); ``` 2. 联合查询: 联合查询用于将两个或多个查询的结果合并成一个结果集。可以使用 `UNION` 或 `UNION ALL` 运算符来执行联合查询。 示例: ```sql SELECT column_name FROM table1 UNION SELECT column_name FROM table2; ``` 3. 分页查询: 分页查询用于在结果集中进行分页显示数据。可以使用 `LIMIT` 子句指定要返回的记录数量,并使用 `OFFSET` 子句指定要跳过的记录数量。 示例: ```sql SELECT column_name FROM table_name LIMIT number_of_rows OFFSET offset_value; ``` 4. 排序: 可以使用 `ORDER BY` 子句对查询结果进行排序。可以按照一个或多个列进行升序或降序排序。 示例: ```sql SELECT column_name FROM table_name ORDER BY column_name ASC; ``` 5. 聚合函数和分组: 使用聚合函数(如 `SUM`、`AVG`、`COUNT` 等)可以对数据进行聚合计算。可以结合 `GROUP BY` 子句将结果集按照一个或多个列进行分组。 示例: ```sql SELECT column_name, COUNT(*) FROM table_name GROUP BY column_name; ``` 这些是一些常用的 MySQL 查询语句高阶用法,可以根据具体需求进行学习和使用。此外,MySQL 还提供了其他高级特性,如窗口函数、子查询优化、索引优化等,可以进一步提升查询性能和灵活性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值