ORACLE 正则解决初使化数据格式不一致

网络编程 2021-07-05 16:08www.168986.cn编程入门
在初使化用户基础数据时会出现一些数据格式不正确的情况。。
如 2000-1-1==> 2000-01-01、2000-01-1==>2000-01-01、2000-1-01==>2000-01-01
以前会写一个function/procedure之类的脚本,大量的IF ELSE。。。
今次无意中发现oracle10g已经支持正则功能,上述问题也就迎刃而解了。。
代码如下:

UPDATE LZ__EQ_RHGL LZRH SET LS__SP_GHTIME = SUBSTR(LZ__SP_GHTIME, 1, 5) || '0' || SUBSTR(LZ__SP_GHTIME, 6, 2) || '0' || SUBSTR(8, 1) WHERE RETEXT_LINE(LZ__SP_GHTIME, '^\d{4}-\d{1}-\d{1}$')

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by