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;

测试结果:

相关推荐
jay丿9 分钟前
使用PyMongo操作MongoDB(一)
数据库·mongodb·oracle
江沉晚呤时14 分钟前
深入解析过滤器模式(Filter Pattern):一种灵活高效的设计模式
java·开发语言·前端·数据库·microsoft·asp.net·.netcore
凡巾1 小时前
河南大学数据库实验4
数据库·oracle
划水的运维1 小时前
GaussDB分布式集群数据库创建database
数据库·分布式·gaussdb
数据知道1 小时前
数据库:一文掌握 MongoDB 的各种指令(MongoDB指令备忘)
数据库·mongodb
背太阳的牧羊人1 小时前
查看 MongoDB 数据库中的表和数据
数据库·mongodb
就改了1 小时前
Redis——事务实现以及应用场景
数据库·redis
猫咪-95271 小时前
Mysql数据类型
数据库·mysql
月熊2 小时前
MySQL单表查询
数据库·mysql
Starshime2 小时前
【MySQL】MySQL登录,访问,退出操作
数据库·mysql·adb