SQL模式匹配允许你使用“_”匹配任何单个字符,而“%”匹配任意数目字符(包括零字符)。在 MySQL中,SQL的模式默认是忽略大小写的。下面给出一些例子。注意使用SQL模
式时,不能使用=或!=;而应使用LIKE或NOT LIKE比较操作符。
1.要想找出以“b”开头的id:
select * from userinfo where userid like 'b%';
2.要想找出以“b”结尾的id
select * from userinfo where userid like '%b';
3.要想找出包含“b”的id:
select * from userinfo where userid like '%b%';
4.要想找出正好包含5个字符的名字,使用“_”模式字符:
select * from userinfo where userid like '_____';
由MySQL提供的模式匹配的其它类型是使用扩展正则表达式。当你对这类模式进行匹配测试时,使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它们是同义词)。
扩展正则表达式的一些字符是:
· ‘.’匹配任何单个的字符。
· 字符类“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的范围,使用一个“-”。“[a-z]”匹配任何字母,而“[0
-9]”匹配任何数字。
· “ * ”匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配任何数量的数字,而“.*”匹配任何数量的任何字符。
如果REGEXP模式与被测试值的任何地方匹配,模式就匹配(这不同于LIKE模式匹配,只有与整个值匹配,模式才匹配)。
为了定位一个模式以便它必须匹配被测试值的开始或结尾,在模式开始处使用“^”或在模式的结尾用“$”。
5.要想找出以“b”或“B”开头的id:
select * from userinfo where userid regexp '^b';
6.想找出以“B”开头的id
select * from userinfo where userid regexp binary '^B';
7.找出数字开头,数字结尾的id
select * from userinfo where userid regexp '^[0-9]*[0-9]$';
8.包含字母“b”的id
select * from userinfo where userid regexp 'b';
9.找出包含正好5个字符的名字
select * from userinfo where userid regexp '^.....$';
10.也可以使用“{n}”“重复n次”操作符重写前面的查询:
select * from userinfo where userid regexp '^.{5}$';
11.字母开头的userid
select * from userinfo where userid regexp '^[a-z]';
12.字母开头字符数为6的userid
select * from userinfo where userid regexp '^[a-z].{5}$';