Oracle SQL: TRANSLATE 和 REGEXP_LIKE 的知识点详细分析

目录

  • 前言
  • [1. TRANSLATE](#1. TRANSLATE)
  • [2. REGEXP_LIKE](#2. REGEXP_LIKE)
  • [3. 实战](#3. 实战)

前言

🤟 找工作,来万码优才:👉 #小程序://万码优才/r6rqmzDaXpYkJZF

1. TRANSLATE

TRANSLATE 用于替换字符串中指定字符集的每个字符,返回替换后的字符串

逐一映射输入字符串的字符到目标字符集,没有提供复杂的模式匹配功能

语法:

sql 复制代码
TRANSLATE(string, from_string, to_string)
  • string:需要替换的原字符串
  • from_string:要被替换的字符集
  • to_string:替换后的字符集

注意:from_string 和 to_string 是按位置一一对应的,to_string 中没有对应字符的位置会被删除

特点:

  • TRANSLATE 不支持正则表达式,仅支持简单的字符替换
  • 如果 from_string 的某个字符没有对应的 to_string 字符,替换后的结果会删除该字符。
    替换后的结果可以为空字符串,但不会返回 NULL

整体Demo如下:

sql 复制代码
-- 示例 1: 基础字符替换
SELECT TRANSLATE('123ABC', '123', 'XYZ') AS RESULT FROM DUAL;
-- 输出: 'XYZABC'

-- 示例 2: 删除字符
SELECT TRANSLATE('123ABC', '123', '') AS RESULT FROM DUAL;
-- 输出: 'ABC'

-- 示例 3: 替换多个字符
SELECT TRANSLATE('HELLO WORLD', 'HEL', 'XYZ') AS RESULT FROM DUAL;
-- 输出: 'XYZO WORLD'

截图如下:

2. REGEXP_LIKE

REGEXP_LIKE 用于对字符串进行正则表达式匹配判断,返回布尔值(TRUE 或 FALSE)

是 Oracle 提供的正则表达式匹配函数,可以处理复杂的字符串模式

特别说明的是

REGEXP_LIKE 在 Oracle 中是一个布尔函数,只能用在条件上下文(如 WHERE、CASE)中,不能直接作为一个结果列返回

基本语法:

sql 复制代码
REGEXP_LIKE(string, pattern [, match_parameter])

基本参数如下:

  • string:需要匹配的字符串
  • pattern:正则表达式
  • match_parameter:可选,用于指定匹配行为(如大小写敏感等)
    'i':忽略大小写
    'c':区分大小写(默认)
    'n':允许匹配字符串中的换行符
    'm':启用多行模式

错误Demo:

sql 复制代码
-- 示例 1: 检查字符串是否仅由数字组成
SELECT REGEXP_LIKE('12345', '^[0-9]+$') AS IS_NUMERIC FROM DUAL;

-- 示例 2: 检查字符串是否包含字母 'A'
SELECT REGEXP_LIKE('123A45', '[A-Za-z]') AS CONTAINS_ALPHA FROM DUAL;

-- 示例 3: 匹配复杂模式(检查是否为邮箱格式)
SELECT REGEXP_LIKE('user@example.com', '^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$') AS IS_EMAIL FROM DUAL;

-- 示例 4: 使用匹配参数忽略大小写
SELECT REGEXP_LIKE('Oracle', '^oracle$', 'i') AS IGNORE_CASE_MATCH FROM DUAL;

会输出如下:ORA-00904: "REGEXP_LIKE": invalid identifier

正确Demo:

在 WHERE 子句中使用 REGEXP_LIKE:

sql 复制代码
-- 示例 1: 检查字符串是否仅由数字组成
SELECT '12345' AS INPUT_VALUE
FROM DUAL
WHERE REGEXP_LIKE('12345', '^[0-9]+$');
-- 输出: '12345'

截图如下:

使用 CASE 包装 REGEXP_LIKE:

sql 复制代码
-- 示例 2: 检查字符串是否包含字母 'A'
SELECT 
    CASE 
        WHEN REGEXP_LIKE('123A45', '[A-Za-z]') THEN 'TRUE'
        ELSE 'FALSE'
    END AS CONTAINS_ALPHA
FROM DUAL;
-- 输出: TRUE

检查复杂模式(如邮箱格式)

sql 复制代码
-- 示例 3: 验证是否为邮箱格式
SELECT 
    CASE 
        WHEN REGEXP_LIKE('user@example.com', '^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$') THEN 'TRUE'
        ELSE 'FALSE'
    END AS IS_EMAIL
FROM DUAL;
-- 输出: TRUE

忽略大小写匹配

sql 复制代码
-- 示例 4: 区分大小写和忽略大小写
SELECT 
    CASE 
        WHEN REGEXP_LIKE('Oracle', '^oracle$', 'i') THEN 'TRUE'
        ELSE 'FALSE'
    END AS IGNORE_CASE_MATCH
FROM DUAL;
-- 输出: TRUE

特别注意:

  • REGEXP_LIKE 是布尔型函数,因此在 SELECT 列表中无法直接输出 TRUE 或 FALSE,需要通过 CASE 转换为可显示的字符串结果
  • 如果在 WHERE 子句中使用,只有匹配成功的记录会返回结果

3. 实战

实战中发现两个字段的格式都不一样:

具体差异如下:

查询内容 第一条查询 TRANSLATE 第二条查询 REGEXP_LIKE
功能差异 替换掉所有数字后检查是否为空字符串 检查字符串是否完全匹配数字正则表达式
处理空格 不处理空格,空格被保留 使用 TRIM 去掉空格后进行匹配
处理特殊字符 替换后仍存在非数字字符会返回非空字符串,不符合计数条件 如果存在特殊字符,直接无法匹配
性能差异 TRANSLATE 速度更快,适合简单字符替换 REGEXP_LIKE 功能更强大,但性能可能稍差
可能的差异 会忽略空格和部分特殊字符的影响,统计结果可能更大 精确匹配数字,统计结果可能更小

实际结果的比较:

DEVICE_ID 第一条结果 (TRANSLATE) 第二条结果 (REGEXP_LIKE)
123456 计入 计入
123456 (多个空格) 不计入 计入 (通过TRIM)
abc123 不计入 不计入
000 计入 计入
123@456 不计入 不计入

如果 DEVICE_ID 存在空格或特殊字符,REGEXP_LIKE 会更精确
如果 DEVICE_ID 仅考虑数字部分,TRANSLATE 会更宽松一些

相关推荐
橘猫云计算机设计2 小时前
基于Django的购物商城平台的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·django
2501_903238652 小时前
Spring Boot日志配置与环境切换实战
数据库·spring boot·后端·个人开发
梓沂2 小时前
审计级别未启用扩展模式导致查询 DBA_AUDIT_TRAIL 时 SQL_TEXT 列为空
数据库·sql·dba
caihuayuan42 小时前
PHP建立MySQL持久化连接(长连接)及mysql与mysqli扩展的区别
java·大数据·sql·spring
Smile丶凉轩2 小时前
数据库面试知识点总结
数据库·c++·mysql
RainbowSea3 小时前
9-1. MySQL 性能分析工具的使用——last\_query\_cost,慢查询日志
数据库·sql·mysql
Sui_Network4 小时前
Sui 如何支持各种类型的 Web3 游戏
大数据·数据库·人工智能·游戏·web3·区块链
ZKNOW甄知科技4 小时前
IT服务运营管理体系的常用方法论与实践指南(上)
大数据·数据库·人工智能
黄雪超5 小时前
深入HBase——核心组件
数据结构·数据库·hbase
qq_529835356 小时前
Redis作为缓存和数据库的数据一致性问题
数据库·redis·缓存