龙空技术网

Oracle根据身份证号码获取年龄的函数

intellijidea 110

前言:

今天咱们对“oracle数据库语句年龄计算到月”大体比较注重,朋友们都想要分析一些“oracle数据库语句年龄计算到月”的相关文章。那么小编在网摘上搜集了一些对于“oracle数据库语句年龄计算到月””的相关资讯,希望姐妹们能喜欢,姐妹们快快来学习一下吧!

最近我在使用Oracle时,碰到根据身份证号码来获取当前的年龄,用其他自带函数拼接得出结果,不是很方便。然后发现数据库本身没有这个函数,然后我自己尝试写了一个函数,就是关于获取年龄的,仅供各位交流学习:

create or replace function FUNC_COMPARE_SFZHM( sfzhm in varchar2) --输入身份证号码  return number  /*  函数说明,返回值0为小于18岁;值为1是大于75岁;其他情况是返回值为2  在这个函数里用到了trunc(months_between())   然后就是将身份证号码里的年月日组合成'yyyy-mm-dd'格式,但是在SQL里拼接用的是"||",而不是"+",这个值得注意  */isbegin    if Trunc(MONTHS_BETWEEN(to_date(to_char(sysdate, 'yyyy-MM-dd'),'yyyy-MM-dd'),to_date(substr(sfzhm,7,4)||'-'||substr(sfzhm,11,2)||'-'||substr(sfzhm,13,2), 'yyyy-MM-dd')) / 12) < 18  then      return 0;      elsif  Trunc(MONTHS_BETWEEN(to_date(to_char(sysdate, 'yyyy-MM-dd'),'yyyy-MM-dd'),to_date(substr(sfzhm,7,4)||'-'||substr(sfzhm,11,2)||'-'||substr(sfzhm,13,2), 'yyyy-MM-dd')) / 12) >75 then    return 1;    else      return 2;    end if;end;

下面是函数调用的SQL语句:

select func_compare_sfzhm('31010320000314XXXX') from dual;//这个地方是举个例子,所以后面四位我用X替代

标签: #oracle数据库语句年龄计算到月 #oracle算年龄的函数 #oracle正则提取13开头的11位数字 #oracle怎么截取年份 #oracle获取去年年份