本文小编为大家详细介绍“MySQL数据库操作DQL正则表达式的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql数据库操作DQL正则表达式的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言:正则
本文小编为大家详细介绍“MySQL数据库操作DQL正则表达式的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql数据库操作DQL正则表达式的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
前言:
正则表达式(regular expression)描述了一种字符串匹配的规则,正则表达式本身就是一个字符串,使用这个字符串来描述、用来定义匹配规则,匹配一系列符合某个句法规则的字符串。在开发中,正则表达式通常被用来检索、替换那些符合某个规则的文本。
mysql通过REGEXP关键字支持正则表达式进行字符串匹配。
-- ^ 在字符串开始处进行匹配SELECT 'abc' REGEXP '^a'; -- 1-- $ 在字符串末尾开始匹配SELECT 'abc' REGEXP 'a$'; -- 0SELECT 'abc' REGEXP 'c$'; -- 1-- . 匹配任意字符SELECT 'abc' REGEXP '.b'; -- 1SELECT 'abc' REGEXP '.c'; -- 1SELECT 'abc' REGEXP 'a.'; -- 1-- [...] 匹配括号内的任意单个字符SELECT 'abc' REGEXP '[xyz]'; -- 0SELECT 'abc' REGEXP '[xaz]'; -- 1
返回值为1就代表匹配到了,如果返回值为0就代表不能匹配
-- [^...] 注意^符合只有在[]内才是取反的意思,在别的地方都是表示开始处匹配SELECT 'a' REGEXP '[^abc]';-- 0SELECT 'x' REGEXP '[^abc]';-- 1SELECT 'abc' REGEXP '[^a]';-- 1
使用[^]则代表的是,不能匹配到,那么有些人肯定会疑问,为什么最后一个却匹配到了,虽然里面包含a,但是[^a]代表的是,除了a,里面还有其他的,也可以匹配成功,这里其实涉及到了一个单词中的全匹配和局部匹配。
负值字符集合。匹配未包含的任意字符。例如, '[^abc]' 可以匹配 "plain" 中的'p'
-- a* 匹配0个或多个a,包括空字符串。 可以作为占位符使用.有没有指定字符都可以匹配到数据SELECT 'stab' REGEXP '.ta*b';SELECT 'stb' REGEXP '.ta*b';SELECT '' REGEXP 'a*';
注意这里的*是0个或者多个,所以最后一个返回的是1
-- a+ 匹配1个或者多个a,但是不包括空字符SELECT 'stab' REGEXP '.ta+b';SELECT 'stb' REGEXP '.ta+b';
注意这里的+是1个或者多个
-- a? 匹配0个或者1个aSELECT 'stb' REGEXP '.ta?b';SELECT 'stab' REGEXP '.ta?b';SELECT 'staab' REGEXP '.ta?b';-- a1|a2 匹配a1或者a2,SELECT 'a' REGEXP 'a|b';SELECT 'b' REGEXP 'a|b';SELECT 'b' REGEXP '^(a|b)';SELECT 'a' REGEXP '^(a|b)';SELECT 'c' REGEXP '^(a|b)';-- a{m} 匹配m个aSELECT 'auuuuc' REGEXP 'au{4}c';SELECT 'auuuuc' REGEXP 'au{3}c';
注意这里的?是0个或者1个,标准的名字叫做非贪婪模式
-- a{m,n} 匹配m到n个a,包含m和nSELECT 'auuuuc' REGEXP 'au{3,5}c';SELECT 'auuuuc' REGEXP 'au{4,5}c';SELECT 'auuuuc' REGEXP 'au{5,10}c';-- (abc) abc作为一个序列匹配,不用括号括起来都是用单个字符去匹配,如果要把多个字符作为一个整体去匹配就需要用到括号,所以括号适合上面的所有情况。SELECT 'xababy' REGEXP 'x(abab)y';SELECT 'xababy' REGEXP 'x(ab)*y';SELECT 'xababy' REGEXP 'x(ab){1,2}y';
一般的实际应用场景,通过正则表达式可以对文本进行匹配,这比之前的like关键字要智能的多,应用场景也是比较的广,所以需要熟悉它的语法标准:
select 字段 regexp '正则表达式' as 命名 from 表 ……
读到这里,这篇“Mysql数据库操作DQL正则表达式的方法”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网数据库频道。
--结束END--
本文标题: MySQL数据库操作DQL正则表达式的方法
本文链接: https://lsjlt.com/news/343230.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0