当前位置: 首页 > 编程笔记 >

mysql中如何使用正则表达式查询

齐泰
2023-03-14
本文向大家介绍mysql中如何使用正则表达式查询,包括了mysql中如何使用正则表达式查询的使用技巧和注意事项,需要的朋友参考一下
基本形式
属性名 regexp ‘匹配方式'
正则表达式的模式字符
^ 匹配字符开始的部分
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)
-可以表示单个字符
 类似资料:
  • 主要内容:查询以特定字符或字符串开头的记录,查询以特定字符或字符串结尾的记录,替代字符串中的任意一个字符,匹配多个字符,匹配指定字符串,匹配指定字符串中的任意一个,匹配指定字符以外的字符,使用{n}或者{nm}来指定字符串连续出现的次数正则表达式主要用来查询和替换符合某个模式(规则)的文本内容。例如,从一个文件中提取电话号码,查找一篇文章中重复的单词、替换文章中的敏感语汇等,这些地方都可以使用正则表达式。正则表达式强大且灵活,常用于非常复杂的查询。 MySQL 中,使用 REGEXP 关键字指定

  • 问题内容: 我有一个简单的任务,我需要搜索一个以字符串字符和其后的一位数字开头的记录。我正在尝试的是 和 但是两个查询总是返回一条记录 好像我执行以下查询 它返回 这意味着我有以ALA开头的记录,其后是一个数字, 编辑 我正在使用PHP MySQL和innodb引擎来实现它。 问题答案: 我认为您可以使用REGEXP代替LIKE

  • 问题内容: 我在数据库中有一些域列表,例如 等等 我需要的是 我怎样才能做到正则表达式??? 问题答案: 在中,正则表达式可以匹配,但不能返回子字符串。 您可以使用: ,但是它不是协议前缀安全的。 如果您混合使用前缀和无前缀,请使用以下命令:

  • 本文向大家介绍如何在TestNG中使用正则表达式?,包括了如何在TestNG中使用正则表达式?的使用技巧和注意事项,需要的朋友参考一下 我们在TestNG中使用正则表达式来使用以某种模式命名的一组测试方法。 示例 Testng xml文件。 所有名称开头为Payment的测试方法都将从回归套件中排除。 示例 Login()将被执行,但是所有以名字Payment开头的方法都将被排除在执行之外。这是使

  • (?:x) (x) 这两个好像可以平价替换的吧。有什么特殊应用吗?

  • 行动时刻 - 使用正则表达式 Unlang允许在条件检查中进行正则表达式计算。这些通常是Posix正则表达式。运算符=〜和!〜与正则表达式相关联。为了简单的概念证明,我们将修改上一个练习: 1.编辑FreeRADIUS配置目录下的sites-available / default虚拟服务器,并在该部分顶部的post-auth部分中添加以下内容: if(request:Framed-Protocol