MySQL进阶语句二

目录

一、正则表达式

二、运算符

1、算术运算符  

2、比较运算符

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

4、位运算符


一、正则表达式

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,否则返回0

select 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
10between, case, when, then, else
11not
12&&,and
13||,or,xor
14:=
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值