一、正则表达式
MySQL 正则表达式通常是在检索数据库记录的时候,根据指定的匹配模式匹配记录中符合要求的特殊字符串。
MySQL 的正则表达式使用REGEXP这个关键字来指定正则表达式的匹配模式,
REGEXP 操作符所支持的匹配模式如下:
匹配模式 描述 实例
^ 匹配文本的开始字符 ‘^bd’ 匹配以 bd 开头的字符串
$ 匹配文本的结束字符 ‘qn$’ 匹配以 qn 结尾的字符串
. 匹配任何单个字符 ‘s.t’ 匹配任何 s 和 t 之间有一个字符的字符串
* 匹配零个或多个在它前面的字符 ‘fo*t’ 匹配 t 前面有任意个 o
+ 匹配前面的字符 1 次或多次 ‘hom+’ 匹配以 ho 开头,后面至少一个m 的字符串
字符串 匹配包含指定的字符串 ‘clo’ 匹配含有 clo 的字符串
p1|p2 匹配 p1 或 p2 ‘bg|fg’ 匹配 bg 或者 fg
[...] 匹配字符集合中的任意一个字符 ‘[abc]’ 匹配 a 或者 b 或者 c
[^...] 匹配不在括号中的任何字符 ‘[^ab]’ 匹配不包含 a 或者 b 的字符串
{n} 匹配前面的字符串 n 次 ‘g{2}’ 匹配含有 2 个 g 的字符串
{n,m} 匹配前面的字符串至少 n 次,至多m 次 ‘f{1,3}’ 匹配 f 最少 1 次,最多 3 次
PS: ^表示匹配开始字符,单需要看'^'所处在的位置,例如:[^]表示不包含
^[],则表示已...为开头
二、运算符
MySQL的运算符用于对记录中的字段值进行运算。MysQ的运算符共有四种,分别是:算术运算符、比较运算符、逻辑运算符和位运算符
算数运算:
运算符 描述
+ 加法
- 减法
* 乘法
/ 除法
% 取余
在除法运算和求余数运算中,除数不能为0,若除数是0,返回的结果则为NULL。
PS:如果有多个运算符,按照先乘除后加减的优先级进行运算,相同优先级的运算符没有先后顺序。

三、比较运算符
字符串的比较默认不区分大小写,可使用binary来区分常用比较运算符(比较对象:数字,字符)
= 等于
!=或<> 不等于
LIKE 通配匹配符
> 大于
>= 大于等于
< 小于
<= 小于等于
IS NULL 判断一个值是否为NULL
IS NOT NULL 判断一个值是否不为NULL
BETWEEN AND 两者之间
GREATEST 两个或多个参数是返回最大值
LEAST 两个或多个参数时返回最小值
IN 在集合中
- 等于(=)
等号(=)用来判断数字、字符串和表达式是否相等的,如果相等则返回1,如果不相等则返回0。
如果比较的两者有一个值是NULL,则比较的结果就是NULL。
PS:其中字符的比较是根据AscII码来判断的,如果ASCcIT码相等,则表示两个字符相同;如果AsCcIT码不相等,则表示两个字符不相同。例如字符串(字母)比较:(‘a’ > ‘b’)其实比较的是底层ascii码
需要关注的ascii码有: a、A、0
示例:
select 2=4,2='2', 'e'='e',(2+2)=(3+1),' 4'=null;

- 不等于(!=或<>)
用于针对数字、字符串和表达式不相等的比较,如果不相等则返回1,如果相等则返回0,与等于(=)的返回值相反,同时不等于(!=,<>)无法用于判断是否为null
示例:
SELECT 'kgc'<>'bdqn',1<>2,3!=3,2.5!=2,NULL<>NULL;

- 大于、大于等于、小于、小于等于运算符
大于(>)运算符用来判断左侧的操作数是否大于右侧的操作数,若大于返回1,否则返回0,同样不能用于判断NULL。
小于(<〉运算符用来判断左侧的操作数是否小于右侧的操作数,若小于返回 1,否则返回0,同样不能用于判断NULL。
大于等于(>=)判断左侧的操作数是否大于等于右侧的操作数,若大于等于返回1,否则返回0,不能用于判断 NULL。
小于等于(<=)判断左侧的操作数是否小于等于右侧的操作数,若小于等于返回1,否则返回0,不能用于判断NULL。
示例:
select 5>4,'a'>'b',2>=3,(2+3)>=(1+2),4.4<3,1<2,'x'<='y',5<=5.5, 'u'>=NULL;

- 判断一个值为/不为null( IS NULL、IS NOT NULL)
IS NULL判断一个值是否为 NULL,如果为NULL返回1,否则返回0。
IS NOT NULL 判断一个值是否不为 NULL,如果不为NULL返回1,否则返回0。
示例:
select 2 IS NULL,'f' IS NOT NULL,NULL IS NULL;

- 两者之间(BETWEEN … AND …)BETWEENAND
比较运算通常用于判断一个值是否落在某两个值之间。
例如,判断某数字是否在另外两个数字之间,也可以判断某英文字母是否在另外两个字母之间,具体操作,条件符合返回1,否则返回0。
示例:
select 4 BETWEEN 2 AND 6,5 BETWEEN 6 AND 8, 'c'BETWEEN 'a'AND 'f';提问:
select 2 between 2 and 6;返回是否为1?

- 当有两个或多个参数时,返回其中最大/最小值,如果一个为null,则返回为null (least greatest)
示例:
SELECT least (1,2,3),least ('a' , 'b ', ' c' ) , greatest(1,2,3) , greatest ( ' a ' , 'b' , ' c ');
数字比较、按大小排列
字母比较,从a-b顺序,字母越前越"小”

- 在/不在集合中(in , not in)
IN判断一个值是否在对应的列表中,如果是返回1,否则返回0
NOT IN判断一个值是否不在对应的列表中,如果不在则返回1,否则返回0
示例:
例如,判断某数字是否在一组数字中,也可判断某字符是否在一组字符中,具体操作如下
SELECT 2 in (1,2,3,4,5),'c' not in ('a','b','C');

- 通配符匹配
LIKE用来匹配字符串,如果匹配成功则返回1,反之返回 0。LIKE支持两种通配符:
'%’用于匹配任意数目的字符,
而“_”只能匹配一个字符。
NOT LIKE 正好跟LIKE相反,如果没有匹配成功则返回1,反之返回0。如:
若要判断某字符串能否匹配成功,分单字符匹配和多字符匹配,也可以判断不匹配,
具体操作如下所示
SELECT 'bdqn' LIKE 'bdq_',' kgc' LIKE '%c','etc' NOT LIKE '%th';

四、逻辑运算符
逻辑运算符又被称为布尔运算符,通常用来判断表达式的真假,如果为真返回1,否则返回0,真和假也可以用TRUB和FALSE 表示。
MySQL中支持使用的逻辑运算符有四种
NOT 或 ! 逻辑非
AND 或 && 逻辑与
OR 逻辑或
XOR 逻辑异或
- 逻辑非( NOT 或 !)
逻辑非将跟在他后面的值取反,如果 NOT后面的操作数为0时,所得值为1;如果操作数为非0时,所得值为0;如果操作数为NULL时,所得值为NULL
小结:返回值为0、1、null值(根据匹配条件判断为何值)
SELECT not 2,!3,not 0,!(4-4);
优先级问题:
mysql>SELECT !1+1,NOT 1 + 1;
为什么!1+1 =1 而not 1+1 =0


- 逻辑与( AND或&& )
AND 和& &都是逻辑与运算符,具体语法规则为:
当所有操作数都为非零值并且不为 NULL时,返回值为 1;当一个或多个操作数为0 时,返回值为0;
操作数中有任何一个为NULL时,返回值为NULL。
SELECT 2 AND 3,4 && 0,0 && NULL,1 AND NULL;
由结果可以看到:
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时,如果另一个操作数为非零值,则返回值为 1,否则结果为NOLL;
假如两个操作数均为NULL时,则返回值为NULL。
使用或运算符OR进行逻辑判断,运行结果如下:示例:
SELECT 2 OR 3,-1 OR 0,5 OR NULL,0 OR NULL,0 OR 0;
小结:
1 OR -1 OR 0含有0,但同时包含有非0的值 -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时,返回值为NULL;
对于非 NULL的操作数,如果两个操作数都是非0值或者都是0值,则返回值为1;
如果一个为0值,另一个为非0值,返回值为1
使用异或运算符xOR进行逻辑判断,SQL语句如下:
select 2 xor 3,0 xor 1,1 xor 0,1 xor null, null xor 3;

五、位运算符
位运算符是在二进制数上进行计算的运算符。
位运算会先将操作数变成二进制数,进行位运算。
然后再将计算结果从二进制数变回十进制数。
& 按位与
| 按位或
^ 按位异或
! 取反
<< 左移
>> 右移
10转换为二进制数是1010,15转换为二进制数是1111
-
按位与运算(&),是对应的二进制位都是1的,它们的运算结果为1,否则为0,所以10 & 15的结果为10。
select 10 & 15;

-
按位或运算(|),是对应的二进制位有一个或两个为1的,运算结果为1,否则为0,所以10 │15的结果为15。
select 10 |15; -
按位异或运算(^),是对应的二进制位不相同时,运算结果1,否则为0,所以10 ^15的结果为5。select 10 ^ 15;
-

-
按位取反(~),是对应的二进制数逐位反转,即1取反后变为0,0取反后变为1。数字 1的二进制是0001,取反后变为1110,数字5的二进制是0101,将1110 和 0101进行求与操作,其结果是二进制的0100,转换为十进制就是4
select 5 &~1;

六、连接查询
MySgL的连接查询,通常都是将来自两个或多个表的行结合起来,基于这些表之间的共同字段,进行数据的拼接。
首先,要确定一个主表作为结果集,然后将其他表的行有选择性的连接到选定的主表结果集上。
使用较多的连接查询包括:内连接、左连接和右连接
实验准备,创建两张表
CREATE TABLE test1 (
a_id int(11) DEFAULT NULL,
a_name varchar(32) DEFAULT NULL,
a_level int(11) DEFAULT NULL);
)
CREATE TABLE test2 (
b_id int(11) DEFAULT NULL,
b_name varchar(32) DEFAULT NULL,
b_level int(11) DEFAULT NULL);
)
insert into test1(a_id, a_name, a_level) values(1, 'aaaa', 10);
insert into test1(a_id, a_name, a_level) values(2, 'bbbb', 20);
insert into test1(a_id, a_name, a_level) values(3, 'cccc', 30);
insert into test1(a_id, a_name, a_level) values(4, 'dddd', 40);
insert into test2(b_id, b_name, b_level) values(2, 'bbbb', 20);
insert into test2(b_id, b_name, b_level) values(3, 'cccc', 30);
insert into test2(b_id, b_name, b_level) values(5, 'eeee', 50);
insert into test2(b_id, b_name, b_level) values(6, 'ffff', 60);

1.内连接
MySQL中的内连接就是两张或多张表中同时符合某种条件的数据记录的组合。通常在 FROM子句中使用关键字INNER JOIN来连接多张表,并使用ON子句设置连接条件,内连接是系统默认的表连接,所以在 FROM子句后可以省略INNER关键字,只使用关键字JOIN。同时有多个表时,也可以连续使用INNER JOIN来实现多表的内连接,不过为了更好的性能,建议最好不要超过三个表
语法:
SELECT column_name(s)FROM table1 INNER JOIN table2 ON table1.column_name = table2.column_name;
示例:
select a.a_id,a.a_name,a.a_level from test1 a inner join test2 b on a.a_id = b.b_id;

2.左连接
左连接也可以被称为左外连接,在 FROM子句中使用LEFT JOIN或者 LEFT OUTER JOIN关键字来表示。
左连接以左侧表为基础表,接收左表的所有行,并用这些行与右侧参考表中的记录进行匹配,
也就是说匹配左表中的所有行以及右表中符合条件的行。
示例:
select * from test1 a left join test2 b on a.a_name=b.b_name;

3.右连接
右连接也被称为右外连接,在 FROM子句中使用RIGHT JOIN 或者 RIGHT OUTER JOIN
关键字来表示。右连接跟左连接正好相反,它是以右表为基础表,用于接收右表中的所有行,并用这些记录与左表中的行进行匹配
select * from test1 a right join test2 b on a.a_name=b.b_name;

本文深入探讨了MySQL中的高阶查询技巧,包括正则表达式的使用、多种运算符的应用、不同类型的连接查询等内容,帮助读者掌握更复杂的数据库操作。
1万+





