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 在集合中
示例:
select 2=4,2='2', 'e'='e',(2+2)=(3+1),' 4'=null;
示例:
SELECT 'kgc'<>'bdqn',1<>2,3!=3,2.5!=2,NULL<>NULL;
示例:
select 5>4,'a'>'b',2>=3,(2+3)>=(1+2),4.4<3,1<2,'x'<='y',5<=5.5, 'u'>=NULL;
示例:
select 2 IS NULL,'f' IS NOT NULL,NULL IS NULL;
示例:
select 4 BETWEEN 2 AND 6,5 BETWEEN 6 AND 8, 'c'BETWEEN 'a'AND 'f';提问:
select 2 between 2 and 6;返回是否为1?
示例:
SELECT least (1,2,3),least ('a' , 'b ', ' c' ) , greatest(1,2,3) , greatest ( ' a ' , 'b' , ' c ');
数字比较、按大小排列
字母比较,从a-b顺序,字母越前越"小”
示例:
例如,判断某数字是否在一组数字中,也可判断某字符是否在一组字符中,具体操作如下
SELECT 2 in (1,2,3,4,5),'c' not in ('a','b','C');
'%’
用于匹配任意数目的字符,“_”
只能匹配一个字符。具体操作如下所示
SELECT 'bdqn' LIKE 'bdq_',' kgc' LIKE '%c','etc' NOT LIKE '%th';
逻辑运算符又被称为布尔运算符,通常用来判断表达式的真假,如果为真返回1,否则返回0,真和假也可以用TRUB和FALSE 表示。
MySQL中支持使用的逻辑运算符有四种
NOT 或 ! 逻辑非
AND 或 && 逻辑与
OR 逻辑或
XOR 逻辑异或
SELECT not 2,!3,not 0,!(4-4);
优先级问题:
mysql>SELECT !1+1,NOT 1 + 1;
为什么!1+1 =1 而not 1+1 =0
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
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进行逻辑判断,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);
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;
左连接也可以被称为左外连接,在 FROM子句中使用LEFT JOIN或者 LEFT OUTER JOIN关键字来表示。
左连接以左侧表为基础表,接收左表的所有行,并用这些行与右侧参考表中的记录进行匹配,
也就是说匹配左表中的所有行以及右表中符合条件的行。
示例:
select * from test1 a left join test2 b on a.a_name=b.b_name;
右连接也被称为右外连接,在 FROM子句中使用RIGHT JOIN 或者 RIGHT OUTER JOIN
关键字来表示。右连接跟左连接正好相反,它是以右表为基础表,用于接收右表中的所有行,并用这些记录与左表中的行进行匹配
select * from test1 a right join test2 b on a.a_name=b.b_name;