玉祥平台客服-15087858732

标题: SQL 根据身份证号码获取年龄的函数 [打印本页]

作者: fteair    时间: 2020-2-14 17:51
标题: SQL 根据身份证号码获取年龄的函数
在数据库的运用过程中,我们时常会碰到根据身份证号码来获取当前的年龄,今天我在这里写了一个函数,就是关于获取年龄的
  1. create or replace function FUNC_COMPARE_SFZHM( sfzhm in varchar2) --输入身份证号码
  2.   return number
  3.   /*
  4.   函数说明,返回值0为小于18岁;值为1是大于75岁;其他情况是返回值为2
  5.   在这个函数里用到了trunc(months_between())
  6.   然后就是将身份证号码里的年月日组合成'yyyy-mm-dd'格式,但是在SQL里拼接用的是"||",而不是"+",这个值得注意
  7.   */
  8. is

  9. begin
  10.     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
  11.       return 0;  
  12.     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
  13.     return 1;
  14.     else
  15.       return 2;
  16.     end if;
  17. end;
复制代码
下面是函数调用的SQL语句:
  1. select func_compare_sfzhm('310103200003141234') from dual;
复制代码


作者: fteair    时间: 2020-2-14 17:51

作者: 张兴康    时间: 2020-2-15 16:15

作者: 张兴康    时间: 2020-2-15 16:22

作者: fteair    时间: 2020-2-15 17:18





欢迎光临 玉祥平台客服-15087858732 (http://bbs.delit.cn/) Powered by Discuz! X3.2