怎么用正则查询mysql mysql 正则替换查询结果

mysql 怎么使用正则表达式

属性名 regexp ‘匹配方式'

10年积累的成都网站设计、做网站经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计制作后付款的网站建设流程,更有甘井子免费网站建设让你可以放心的选择与我们合作。

正则表达式的模式字符

^ 匹配字符开始的部分

eg1: 从info表name字段中查询以L开头的记录

select * from info where name regexp '^L';

eg2: 从info表name字段中查询以aaa开头的记录

select * from info where name regexp '^aaa';

$ 匹配字符结束的部分

eg1: 从info表name字段中查询以c结尾的记录

select * from info where name regexp 'c$';

eg2: 从info表name字段中查询以aaa结尾的记录

select * from info where name regexp 'aaa$';

. 匹配字符串中的任意一个字符,包括回车和换行

eg1: 从info表name字段中查询以L开头y结尾中间有两个任意字符的记录

select * from info where name regexp '^L..y$';

[字符集合]匹配字符集合中的任意字符

eg1: 从info表name字段中查询包含c、e、o三个字母中任意一个的记录

select * from info where name regexp '[ceo]';

eg2: 从info表name字段中查询包含数字的记录

select * from info where name regexp '[0-9]';

eg3: 从info表name字段中查询包含数字或a、b、c三个字母中任意一个的记录

select * from info where name regexp '[0-9a-c]';

[^字符集合]匹配除了字符集合外的任意字符

eg1: 从info表name字段中查询包含a-w字母和数字以外字符的记录

select * from info where name regexp '[^a-w0-9]';

s1|s2|s3 匹配s1s2s3中的任意一个

eg1: 从info表name字段中查询包含'ic'的记录

select * from info where name regexp 'ic';

eg2: 从info表name字段中查询包含ic、uc、ab三个字符串中任意一个的记录

select * from info where name regexp 'ic|uc|ab';

* 代表多个该字符前的字符,包括0个或1个

eg1: 从info表name字段中查询c之前出现过a的记录

select * from info where name regexp 'a*c';

+ 代表多个该字符前的字符,包括1个

eg1: 从info表name字段中查询c之前出现过a的记录

select * from info where name regexp 'a+c';(注意比较结果!)

字符串{N} 字符串出现N次

eg1: 从info表name字段中查询出现过a3次的记录

select * from info where name regexp 'a{3}';

字符串{M,N}字符串最少出现M次,最多出现N次

eg1: 从info表name字段中查询ab出现最少1次最多3次的记录

select * from info where name regexp 'ab{1,3}';

MYSQL中自带通配符(LIKE关键词)

%可以表示任意长度的字符(包括0)

-可以表示单个字符

mysql数据库正则查询

[]表示的是范围,就是说只匹配里面的单个字符或范围,同样的字符写多次和写一次效果一样

如果是一般情况,可以用(?!55)$或者(?!55)$匹配,但是mysql数据库不支持这些非获取匹配的写法,所以还是用not regexp '55$'来筛选吧

MySQL如何实现正则查找替换?

mysql的正则匹配用regexp,而替换字符串用REPLACE(str,from_str,to_str)例如UPDATE myTable SET HTML=REPLACE(HTML,'','') WHERE HTML REGEXP '( */*\s*){2,}'

可是这么写会把所有全部替换掉,因此干脆把REPLACE(HTML,'','')改成REPLACE(HTML,substr(HTML,locate('',HTML)+strlen(''),strlen('')),'')

这还不够,还得手动写多个''、'///',

还不够,还得循环数次这些命令。。。。

关键的是,SQL语句无法实现正则匹配后取其中一部分的字符串来替换,所以你这里用sql实现是异常蛋疼的,干脆在程序里做正则替换,然后update吧。

mysql 正则表达式 查询匹配 某个词

\w是匹配[a-zA-Z0-9] . ? 匹配一个或者0个前面的字符,* 匹配前面0个或者多个字符。

所以这个正则表达式匹配前面具有数字或者字母开头的,中间为word,后面为数字或者字母结尾的字符串。开头和结尾不能同时出现字母和数字。

以下几个例子可匹配:

11111111111wordcccccccccccccccccc

aaaaaaaaaaawordxxxxxxxxxxxxxxxxxx


文章名称:怎么用正则查询mysql mysql 正则替换查询结果
路径分享:http://ybzwz.com/article/dogpogo.html