oracle 根据身份证号码与指定日期计算年龄

自定义函数:

sql 复制代码
CREATE OR REPLACE FUNCTION 获取年龄(身份证号 varchar2, 指定时间 date)
RETURN varchar2
AS
年龄 varchar2(16);
BEGIN
  if length(身份证号) >=18 then
    SELECT TRUNC(    MONTHS_BETWEEN(指定时间,     TO_DATE(SUBSTR(身份证号, 7, 8), 'YYYYMMDD')    )   / 12) || '岁' into 年龄 FROM DUAL;
    if 年龄 ='0岁' then
      SELECT TRUNC(MONTHS_BETWEEN(指定时间, TO_DATE(SUBSTR(身份证号, 7, 8), 'YYYYMMDD'))) || '个月' into 年龄 FROM DUAL;
      if 年龄 ='0个月' then
         SELECT (TRUNC(指定时间) - TO_DATE(SUBSTR(身份证号, 7, 8), 'YYYYMMDD')) || '天'  into 年龄 FROM DUAL;
         if 年龄 ='0天' then
            SELECT '1天'  into 年龄 FROM DUAL;
         end if;
      end if;
    end if;
  end if;
   RETURN 年龄;

END;

测试结果:

相关推荐
沃尔威武5 小时前
数据库 Sinks(.net8)
数据库·.net·webview
Dreamboat¿6 小时前
SQL 注入漏洞
数据库·sql
曹牧7 小时前
Oracle数据库中,将JSON字符串转换为多行数据
数据库·oracle·json
被摘下的星星7 小时前
MySQL count()函数的用法
数据库·mysql
末央&7 小时前
【天机论坛】项目环境搭建和数据库设计
java·数据库
徒 花7 小时前
数据库知识复习07
数据库·作业
素玥7 小时前
实训5 python连接mysql数据库
数据库·python·mysql
jnrjian7 小时前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
韶博雅8 小时前
emcc升级
oracle
瀚高PG实验室8 小时前
审计策略修改
网络·数据库·瀚高数据库