目录
一、正则表达式
MySQL正则表达式通常是在检索数据库记录的时候,根据指定的匹配模式匹配记录中符合要求的特殊字符串。MySQL的正则表达式使用 regexp 这个关键字来指定正则表达式的匹配模式,regexp 操作符所支持的匹配模式。
查询以 ^A 开头的信息
select id,name from 表名 where name regexp '^A ';
查询以 B$ 结尾的信息
select id,name from 表名 where name regexp ' B$';
查询名字中包含 的信息
select id,name from 表名 where name regexp ' ';
查询名字是 C开头, D结尾,中间不知道是一个什么字符的信息
select id,name from 表名 where name regexp ' C.D';
查询名字中包含 E或者 F 的学生信息
select id,name from 表名 where name regexp ' E | F ';
查询名字中有 G, 可有可无的学生信息
必须要有的部分是' ’而' '可有可无
select id,name from 表名 where name regexp ' *' ;
查询名字中含有 H , 至少出现一次的学生信息
select id, name from 表名 where name regexp ' H +' ;
查询名字以 - 开头的学生信息
select id,name from 表名 where name regexp '^[ - ]';
查询名字不是 的学生信息
select id,name from 表名 where name regexp ' [^ ]';
查询学生名字不以 ... 开头的学生信息
select id,name from 表名 where name regexp '^[^ ]';
匹配 | 描述 |
^ | 匹配文本的开始字符 |
$ | 匹配文本的结束字符 |
. | 匹配任何单个字符 |
* | 匹配零个或多个在它前面的字符 |
% | 匹配所有 |
+ | 匹配前面的字符1次或多次 |
? | |
字符串 | 匹配包含指定的字符串 |
p1 | p2 | 匹配p1或p2 |
[ ... ] | 匹配字符集合中的任意一个字符 |
[ ^... ] | 匹配不在括号中的任何字符 |
[ n ] | 匹配前面的字符串n次 |
[ n,m ] | 匹配前面的字符串至少n次,至多m次 |
二、运算符
MySQL的运算符用于对记录中的字段值进行运算。MySQL的运算符共有四种,分别是:算术运算符、比较运算符、逻辑运算符和位运算符。
1、算术运算符
以 select 命令来实现最基础的加减乘除运算,MySQL支持使用的算术运算符。
运算符 | 描述 |
+ | 加法 |
- | 减法 |
* | 乘法 |
/ | 除法 |
% | 取余 |
在除法运算和求余数运算中,除数不能为0,若除数是0,返回的结果则为NULL。需要注意的是,如果有多个运算符,按照先乘除后加减的优先级进行运算,相同优先级的运算符没有先后顺序。
select 1+2,2-1,3*4,4/2,582;
create table 表名 as select 1+2,2-1, 3*2, 4/2, 582;
select * from 表名;
2、比较运算符
比较运算符是查询数据记录时经常使用的一类运算符。通过使用比较运算符可以判断出
表中有哪些记录是符合条件的,如果比较的结果(以布尔值的方式进行返回判断)为真则返回1,如果为假则返回0,比较的结果如果不确定则返回NULL。其中字符串在进行比较的时候默认是不区分大小写的,如果要区分大小写可以通过binary关键字来实现。
运算符 | 描述 |
= | 等于 |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于等于 |
!=或< > | 不等于 |
is null | 判断一个值是否为null |
is not null | 判断一个值是否不为null |
between and | 两者之间 |
in | 在集合中 |
like | 通配符匹配 |
greatest | 两个或多个参数时返回最大值 |
least | 两个或多个参数时返回最小值 |
regexp | 正则表达式 |
等号 (=)是用来判断数字、字符串和表达式是否相等的,如果相等则返回1,如果不相等则返回0。如果比较的两者有一个值是NULL, 则比较的结果就是NULL。 其中字符的比较是根据ASCII 码来判断的,如果ASCII码相等,则表示两个字符相同:如果ASCII 码不相等,则表示两个字符不相同。
字符串(字母)比较:('a'>'b')其实比较的就是底层的ASCII码
需要关注的是ascii码有: a、A、0 (97、 65、48 )。
与linux返回值表达相反,linux中运行正常返回值是0,运行异常返回值是非0。
select 2=3; 不成立返回0
select 2<3; 成立返回1
① 如果两者都是整数,则按照整数值进行比较。
② 如果一个整数一个字符串,则会自动将字符串转换为数字,再进行比较。 (在程序中,一般是不会吧这两者进行相比较的)
③ 如果两者都是字符串,则按照字符串进行比较。
④ 如果两者中至少有一一个值是NULL, 则比较的结果是NULL。
不等于(<>, !=)
不等于号有两种写法,分别是<>或者!=,用于针对数字、字符串和表达式不相等的比较。如果 不相等则返回1,如果相等则返回0,这点正好跟等于的返回值相反。需要注意的是不等于运算符不能用于判断NULL。
select 'ab'<>'ba';
select 1!=2;
大于(>)运算符
用来判断左侧的操作数是否大于右侧的操作数,若大于返回1,否则返回0,同样不能用于判断NULL。
小于(<)运算符
用来判断左侧的操作数是否小于右侧的操作数,若小于返回1,否则返回0,同样不能用于判断NULL。
大于等于| (>=)判断左侧的操作数是否大于等于右侧的操作数,若大于等于返回1,否则返回0,不能用于判断NULL。
小于等于(<=)判断左侧的操作数是否小于等于右侧的操作数,若小于等于返回1,否则返回0,不能用于判断NULL。
select 1>2;
select 3>1;
select 5>=6;
select 7>=10;
between and #比较运算通常用于判断一个值是否落在某两个值之间。
#判断某数字是否在另外两个数字之间,也可以判断某英文字母是否在另外两个字母之间。
least 和greatest (取最小值、取最大值)
least: 当有两个或者多个参数时,返回其中的最小值。如果其中一个值为NULL, 则返回结果就为NULL。
greatest: 当有两个或者多 个参数时,返回其中的最大值。如果其中一 个值为NULL,则返回结果就为NULL。
若要判断一组数字或字母中哪个最小、哪个最大,可以通过使用LEAST和GREATEST 来实现。
select least (1,2,3);select greatest(1,2,3);
select least('a','b','c');
select greatest('a','b','c');
in判断一个值是否在对应的列表中,如果是返回1,否则返回0。
not in 判断一个值是否不在对应的列表中,如果不是返回1,否则返回0select 1 in (1,2,3);
select 2 not in ('a', 'b', 'c');
like 用来匹配字符串,如果匹配成功则返回1, 反之,返回0
like 支持两种通配符: 'B' 用于匹配任意数目的字符(*匹配的是前面一个字符),而'_'只能匹配一个字符。
not like 正好跟like相反,如果没有匹配成功则返回1,反之返回0。select 'abc' like 'ab8';
select 'abc' like '_ bc';
select 'abc' not like 'a%';
3、逻辑运算符(布尔值)
逻辑运算符又被称为布尔运算符,通常用来判断表达式的真假,如果为真返回1, 否则返回0,真和假也可以用 true 和 false 表示。MySQL中支持使用的逻辑运算符有四种。
运算符 | 描述 |
not或! | 逻辑非 |
and 或 && | 逻辑与 |
or | 逻辑或 |
xor | 逻辑异或 |
1.逻辑非
逻辑运算符中最简单的运算符就是逻辑非,逻辑非使用not。 或 ! 表示。
逻辑非将跟在它后面的逻辑测试取反,把真变为假,把假变为真。如果not后面的操作数为0时,所得值为1:如果操作数为非0时,所得值为0:如果操作数为NULL时,所得值为NULL。select not 2;
select !2;2.逻辑与(and)
当所有的操作数都为非0值且不为null时,返回值为1,否则为0(null与0比较特殊)逻辑与使用and 或者 &&表示
select 2 and 3;
select 4 && 0;
由结果可看出
and 和&&的作用相同
1 and -1没有0或null,所以返回值为1
1 and 0中由有0,所以返回值为0
1 and null 有Null,所以返回值为null
null and 0返回值为0
3.逻辑或(or)
逻辑或通常使用or。
逻辑或表示包含的操作数,任意一个为非零值并且不是NULL值时,返回1,否则返回0。
当有一个操作数为nul1时,如果另一个操作数为非0值,则返回值为1,否则为null。
如两个操作数均为null,则返回值为null。
使用或运算符or进行逻辑判断,运行:select 2 or 3;
select 2 or null;
select 0 or null or 2;
select null or null;
select 0 or null;
4.逻辑异或(xor )
两个非NULL 值的操作数,如果两者都是0或者都是非0,则返回0。
如果一个为0,另一个为非0,则返回结果为1。
当任意一个值为NULL 时,返回值为NULL。select 2 xor 3;
select1 xor 0;
select 0 xor null,;
select null xor null;
4、位运算符
位运算符实际上是对二进制数进行计算的运算符。MySQL内位运算会先将操作数变成二二进制格式(1010 1111),然后进行位运算,最后再将计算结果从二进制变回到十进制格式,方便用户查看。MySQL支持6种位运算符。
位运算符 | 描述 |
& | 按位与 |
| | 按位或 |
~ | 按位取反 |
^ | 按位异或 |
<< | 按位左移 |
>> | 按位右移 |
select 10 & 15;
select 10 | 15;
select 10 | 15;
select 5 &~1;
10转换为二进制数是1010, 15转换为二进制数是1111。
按位与运算(&),是对应的二进制位都是1的,它们的运算结果为1,否则为0,所以10 & 15的结果为10。
按位或运算(1),是对应的二进制位有一个或两个为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 | := |