导读:本期聚焦于小伙伴创作的《Oracle substr函数怎么用?有哪些常见使用场景》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Oracle substr函数怎么用?有哪些常见使用场景》有用,将其分享出去将是对创作者最好的鼓励。

在Oracle数据库的日常开发中,字符串处理是很常见的操作,substr作为内置的字符串截取函数,使用频率非常高,不过不少用户对它的参数规则和使用细节还存在疑惑,下面我们就详细讲解它的用法。

Oracle substr函数怎么用?有哪些常见使用场景

Oracle substr函数基本语法

substr函数的核心作用是从源字符串中截取指定长度的子字符串,它的完整语法有两种形式:

-- 语法1:指定起始位置和截取长度
SUBSTR(string, start_position, [length])

-- 语法2:只指定起始位置,截取到字符串末尾
SUBSTR(string, start_position)

各个参数的含义如下:

  • string:必填参数,表示需要被截取的源字符串,可以是字符类型的字段、字符串常量或者返回字符串的表达式。
  • start_position:必填参数,表示截取的起始位置,需要注意Oracle中字符串的索引是从1开始的,不是从0开始。
  • length:可选参数,表示需要截取的长度,如果省略该参数,函数会从起始位置开始一直截取到源字符串的末尾。

参数细节说明

起始位置的特殊规则

start_position的取值可以是正数也可以是负数:

  • 当start_position为正数时,从字符串的左边第start_position位开始截取。
  • 当start_position为负数时,从字符串的右边第abs(start_position)位开始截取,也就是从末尾往前数。

截取长度的特殊规则

  • 如果length的值大于从起始位置到字符串末尾的剩余长度,函数会自动截取到字符串末尾,不会报错。
  • 如果length的值为0或者负数,函数会返回空字符串。

常见使用示例

下面通过实际的SQL示例来展示不同场景下的使用效果:

-- 示例1:从左边开始截取,指定起始位置和长度
SELECT SUBSTR('HelloWorld', 1, 5) AS result FROM DUAL;
-- 返回结果:Hello

-- 示例2:从左边开始截取,不指定长度,截取到末尾
SELECT SUBSTR('HelloWorld', 6) AS result FROM DUAL;
-- 返回结果:World

-- 示例3:使用负数起始位置,从右边开始数位置
SELECT SUBSTR('HelloWorld', -5, 3) AS result FROM DUAL;
-- 返回结果:Wor

-- 示例4:截取长度超过剩余长度,自动截取到末尾
SELECT SUBSTR('HelloWorld', 6, 10) AS result FROM DUAL;
-- 返回结果:World

-- 示例5:对表字段使用substr函数
-- 假设有用户表user_info,id_card字段存储身份证号,截取前6位作为地区码
SELECT id, SUBSTR(id_card, 1, 6) AS area_code FROM user_info;

实际开发常见场景

  • 身份证号处理:截取身份证号的前6位作为地区码,第7到14位作为出生日期,倒数第2位判断性别。
  • 手机号脱敏:截取手机号前3位和后4位,中间用星号替换,实现隐私保护。
  • 日志内容提取:从长日志字符串中截取关键的错误码或者关键信息片段。
  • 日期格式处理:如果日期存储为字符串格式,可以用substr截取年、月、日部分做单独处理。

注意事项

1. Oracle的substr函数索引从1开始,和很多编程语言从0开始不同,使用时不要混淆。
2. 如果源字符串是NULL,substr函数的返回值也是NULL。
3. 处理中文字符时,需要注意数据库字符集,一般UTF8下一个中文占3个字节,如果是按字节截取可能会出现乱码,这时候可以结合length函数判断字符长度。

熟练掌握substr函数的用法,可以极大提升Oracle字符串处理的效率,应对大部分截取需求都能轻松解决。

Oraclesubstr函数字符串截取SQL函数数据库操作修改时间:2026-06-01 22:01:42

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。