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
相关推荐
liyongjie7 分钟前
mysql和oracle函数比较
mysql·adb·oracle
ehviwer2328 分钟前
新功能全揭秘!FL Studio24.1.1版大更新,快来尝鲜!
前端·数据库·windows·macos·媒体·idm
程序者王大川33 分钟前
【MySQL】索引优化:怎么通过IN查询2000个参数?
数据库·学习·mysql
飞酱不会电脑41 分钟前
云计算第二阶段---DBA Day05-DAY07
运维·数据库·安全·云计算·dba
Flora_Fang42 分钟前
PL/SQL调用REST API上传附件
数据库·plsql
CN.LG1 小时前
浅谈Sql Server 增删改查
java·开发语言·数据库
天天打码1 小时前
2024年6月中国数据库排行榜:蚂蚁集团OceanBase夺魁首登顶
数据库·oceanbase
rylzdz1 小时前
项目中Redis常见的一些问题(缓存穿透,缓存雪崩,内存耗尽等)
数据库·redis·缓存
Yawesh_best2 小时前
Qt (10)【Qt窗口 —— 如何在窗口中创建浮动窗口和状态栏】
数据库·qt·系统架构
天狼12222 小时前
mysql 导入excel文件 navicate
android·数据库·mysql