需求:要截取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表示填充的数字。
总结:字符串的操作简直太神奇了,这里也可以使用正则表达式,可惜对正则实在是囊中羞涩啊!!!