oracle根据身份证字段信息,更新出生日期字段

updated401_ltsetD401_04=substr(d401_01,7,8)wherelengthb(d401_01)=18;我先更新18位的身份证号这样写报错... update d401_lt set D401_04=substr(d401_01,7,8) where lengthb(d401_01)=18;我先更新18位的身份证号

这样写报错,

求高手指点!
展开
 我来答
badkano
2016-01-07 · 知道合伙人体育行家
badkano
知道合伙人体育行家
采纳数:144776 获赞数:885372
团长

向TA提问 私信TA
展开全部

身份证号码的长度分为15位和18位,改法不同,但在oracle中可用一句话来更新。

1、如shenfenzheng表中数据如下:

2、现要更新hiredate字段,使之为身份证号码信息中的出生日期。可用如下语句:

update shenfenzheng set hiredate=case when length(sfz_id)=18 then substr(sfz_id,7,8) else '19'||substr(sfz_id,7,6) end;
commit;

3、更新后结果:

百度网友fc82f346e
2012-07-23 · TA获得超过904个赞
知道小有建树答主
回答量:309
采纳率:0%
帮助的人:187万
展开全部
首先确认你的出生日期字段为日期型,如果不是,执行
update d401_lt set D401_04=to_date(substr(d401_01,7,8),'YYYY-MM-DD') where lengthb(d401_01)=18

其次,检查你的数据,应该是数据出问题了,看看有没中文下的数字,执行
select distinct substr(d401_01,7,8) from d401_lt where lengthb(d401_01)=18
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
忆似血中剑
2012-07-23 · TA获得超过275个赞
知道小有建树答主
回答量:556
采纳率:0%
帮助的人:254万
展开全部
update d401_lt set D401_04=to_date(substr(d401_01,7,8),'YYYY-MM-DD') where lengthb(d401_01)=18
再试下呗。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式