mysql正则表达式提取指定字符
时间:2023年12月09日
/来源:网络
/编辑:佚名
1.REGEXP 正则表达式
# 查找字段中包含数字和字母的所有记录
SELECT 字段1 FROM 表1 where 字段1 REGEXP '[0-9|A-Za-z]+'
# 查找字段中"不"包含数字和字母的所有记录
SELECT 字段1 FROM 表1 where 字段1 NOT REGEXP '[0-9|A-Za-z]+'
eg:
SELECT scheme_name FROM 表1 WHERE scheme_name REGEXP '[0-9|A-Za-z]+';
SELECT DISTINCT scheme_name FROM 表1 WHERE scheme_name not REGEXP '[0-9|A-Za-z]+';
2.REGEXP_REPLACE
使用正则表达式来进行匹配替换:
REGEXP_REPLACE('需要进行替换的字段‘, ‘被替换的关键字’,‘替换的内容’)
-- 1.替换数字
SELECT REGEXP_REPLACE(字段1,'[0-9]','') AS '转换1' FROM 表1;
-- 2.替换数字+字母
SELECT REGEXP_REPLACE(字段1,'[0-9|A-Za-z]','') AS '转换2' FROM 表1;
-- 3.通过update删除字段中原有的数字和字母
update 表1 set 字段1 = REGEXP_REPLACE(字段1,'[0-9|A-Za-z]','');
eg:
SELECT scheme_name, REGEXP_REPLACE(scheme_name,'[0-9|A-Za-z]','') AS '转换2' FROM 表1;
3.补充
模式 说明
^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘\n’ 或 ‘\r’ 之后的位置。
$ 匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 ‘\n’ 或 ‘\r’ 之前的位置。
. 匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任何字符,请使用象 ‘[.\n]’ 的模式。
[…] 字符集合。匹配所包含的任意一个字符。例如, ‘[abc]’ 可以匹配 “plain” 中的 ‘a’。
[^…] 负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以匹配 “plain” 中的’p’。
* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 “z” 以及 “zoo”。* 等价于{0,}。
+ 匹配前面的子表达式一次或多次。例如,‘zo+’ 能匹配 “zo” 以及 “zoo”,但不能匹配 “z”。+ 等价于 {1,}。
{n} n 是一个非负整数。匹配确定的 n 次。例如,‘o{2}’ 不能匹配 “Bob” 中的 ‘o’,但是能匹配 “food” 中的两个 o。
{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。
eg:
1、查找字段1中以240为开头的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP '^240';
2、查找字段1中以el为结尾的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP 'el$';
3、查找字段1中包含seventeen字符串的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP 'seventeen';
4、查找字段1中以元音字符开头或以el字符串结尾的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP '^[aeiou]|el$';
SELECT scheme_name FROM 表1 WHERE scheme_name REGEXP '胶粉';
# 查找字段中包含数字和字母的所有记录
SELECT 字段1 FROM 表1 where 字段1 REGEXP '[0-9|A-Za-z]+'
# 查找字段中"不"包含数字和字母的所有记录
SELECT 字段1 FROM 表1 where 字段1 NOT REGEXP '[0-9|A-Za-z]+'
eg:
SELECT scheme_name FROM 表1 WHERE scheme_name REGEXP '[0-9|A-Za-z]+';
SELECT DISTINCT scheme_name FROM 表1 WHERE scheme_name not REGEXP '[0-9|A-Za-z]+';
2.REGEXP_REPLACE
使用正则表达式来进行匹配替换:
REGEXP_REPLACE('需要进行替换的字段‘, ‘被替换的关键字’,‘替换的内容’)
-- 1.替换数字
SELECT REGEXP_REPLACE(字段1,'[0-9]','') AS '转换1' FROM 表1;
-- 2.替换数字+字母
SELECT REGEXP_REPLACE(字段1,'[0-9|A-Za-z]','') AS '转换2' FROM 表1;
-- 3.通过update删除字段中原有的数字和字母
update 表1 set 字段1 = REGEXP_REPLACE(字段1,'[0-9|A-Za-z]','');
eg:
SELECT scheme_name, REGEXP_REPLACE(scheme_name,'[0-9|A-Za-z]','') AS '转换2' FROM 表1;
3.补充
模式 说明
^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘\n’ 或 ‘\r’ 之后的位置。
$ 匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 ‘\n’ 或 ‘\r’ 之前的位置。
. 匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任何字符,请使用象 ‘[.\n]’ 的模式。
[…] 字符集合。匹配所包含的任意一个字符。例如, ‘[abc]’ 可以匹配 “plain” 中的 ‘a’。
[^…] 负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以匹配 “plain” 中的’p’。
* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 “z” 以及 “zoo”。* 等价于{0,}。
+ 匹配前面的子表达式一次或多次。例如,‘zo+’ 能匹配 “zo” 以及 “zoo”,但不能匹配 “z”。+ 等价于 {1,}。
{n} n 是一个非负整数。匹配确定的 n 次。例如,‘o{2}’ 不能匹配 “Bob” 中的 ‘o’,但是能匹配 “food” 中的两个 o。
{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。
eg:
1、查找字段1中以240为开头的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP '^240';
2、查找字段1中以el为结尾的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP 'el$';
3、查找字段1中包含seventeen字符串的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP 'seventeen';
4、查找字段1中以元音字符开头或以el字符串结尾的所有数据:
SELECT 字段1 FROM 表1 WHERE 字段1 REGEXP '^[aeiou]|el$';
SELECT scheme_name FROM 表1 WHERE scheme_name REGEXP '胶粉';
新闻资讯 更多
- 【帝国cms教程】帝国CMS模板变量$GLOBALS[navclassid]用法分析04-03
- 【帝国cms教程】鲜为人知帝国CMS内容页调用上一篇和下一篇的精华方法汇总04-03
- 【帝国cms教程】怎么快速找出帝国CMS数据库配置文件路径及迁移网站后修改技巧!04-03
- 【帝国cms教程】帝国CMS模板$GLOBALS[navclassid]用法详解04-03
- 【帝国cms教程】帝国cms 7.5版列表页分页样式修改笔记04-02
- 【帝国cms教程】解决帝国CMS搜索页面模板不支持灵动标签和万能标签的方法04-02
- 【帝国cms教程】帝国CMS只备份栏目和模板的方法04-02
- 【帝国cms教程】帝国CMS怎样删除清空数据库记录?04-02
热门文章
- 178Moban源码谈谈免费源码与收费源码的区别
- 2帝国CMS忘记后台登陆用户名、密码、认证码的解决方法
- 3帝国CMS(EmpireCMS) v7.5后台任意代码执行漏洞及具体修复方法
- 4帝国CMS和WordPress 哪个好?哪个适合建站?
- 5如何解决Discuz的密码错误次数过多请15分钟后登陆的问题
- 6帝国cms灵动标签取得内容和栏目链接地址
- 7emlog pro 注册码“开心”教程(如果有一天,emlog官方版 或者 emlog免费版 跑路了,那用户怎么办?)
- 8织梦CMS在nginx下设置伪静态方法(附nginx伪静态规则)
- 9帝国cms后台登录出现”您还未登录”怎么解决?
- 10帝国cms7.5忘记登录密码 和忘记登录认证码以及多次登录 失败被锁定解决办法