码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-03-14 12:57:33      阅读:812      评论:0      收藏:0      [点我收藏+]

标签:arch   run   pre   dual   说明   sql语句   trunc   begin   nbsp   

在数据库的运用过程中,我们时常会碰到根据身份证号码来获取当前的年龄,今天我在这里写了一个函数,就是关于获取年龄的

create or replace function FUNC_COMPARE_SFZHM( sfzhm in varchar2) --输入身份证号码
  return number
  /*
  函数说明,返回值0为小于18岁;值为1是大于75岁;其他情况是返回值为2
  在这个函数里用到了trunc(months_between()) 
  然后就是将身份证号码里的年月日组合成‘yyyy-mm-dd‘格式,但是在SQL里拼接用的是"||",而不是"+",这个值得注意
  */
is

begin
    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(310103200003141234) from dual;

 

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

标签:arch   run   pre   dual   说明   sql语句   trunc   begin   nbsp   

原文地址:https://www.cnblogs.com/suyun0702/p/8566278.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!