需求:要截取Oracle数据库中某一字段中的最后的数字作为流水号自增
如图:
Oracle中截取字符串使用的substr函数
substr函数介绍
- 语法:
substr(string,start,length) - 参数:
string - 指定的要截取的字符串,也可以是字段
start - 必需,规定在字符串的何处开始
正数 - 在字符串的指定位置开始
负数 - 在从字符串结尾的指定位置开始
0 - 在字符串中的第一个字符处开始
length - 可选,指定要截取的字符串长度,缺省时返回字符表达式的值结束前的全部字符。
sql
select substr(problem_id,-5,5) from CS_TECHNICAL_MATTER
运行结果:
附加题:由于要让字段自增,所以当00001 + 1的时候,就变成了2,这不符合需求,所以需要保留前面的0,这需要使用 PadLeft(5,‘0’)函数,5是指保留几位,0表示填充的数字。
总结:字符串的操作简直太神奇了,这里也可以使用正则表达式,可惜对正则实在是囊中羞涩啊!!!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。