mysql 正则表达式用法(一)

记录下关于mysql中regexp 正则匹配字符串的相关用法

一、匹配字符类

markup 复制代码
[:alnum:]  任意字母和数字(同[a-zA-Z0-9])
[:alpha:]  任意字符(同[a-zA-Z])
[:blank:]  空格和制表(同[\t])
[:cntrl:]  ASCII控制字符(ASCII 0到31和127)
[:digit:]  任意数字(同[0-9])
[:graph:]  与[:print:]相同,但不包括空格
[:lower:]  任意小写字母(同[a-z])
[:print:]  任意可打印字符
[:punct:]  既不在[:alnum:]又不在[:cntrl:]中的任意字符
[:space:]  包括空格在内的任意空白字符(同[\f\n\r\t\v])
[:upper:]  任意大写字母(同[A-Z])
[:xdigit:] 任意十六进制数字(同[a-fA-F0-9])

二、特定需求

  1. 仅匹配字符串内存在空格的情况
    方法1: select case when '123 456' regexp '^[^ ]+.*[[:blank:]].*[^ ]+$' then 1 else 0 end check_status
  2. 仅匹配字符串两端存在空格的情况
    方法1: 使用trim()函数来判断: select case when trim(check_col) != check_colthen 1 else 0 end check_status
    方法2: 正则判断 select case when '123' regexp '^ | $' then 1 else 0 end check_status
  3. 匹配非内部空格,包含两端空格以及\f\n\r\t\v等字符的情况
    方法: select case when check_col regexp '[[:space:]]' and check_colnot regexp '^[^ ]+.*[[:blank:]].*[^ ]+$' then 1 else 0 end check_status
相关推荐
weelinking2 分钟前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_8039346138 分钟前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋91 小时前
windows中安装redis
数据库·redis·缓存
Cosolar2 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap2 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++
小江的记录本2 小时前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
SeaTunnel2 小时前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特2 小时前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_3 小时前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze3 小时前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库