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;

测试结果:

相关推荐
杨过过儿16 分钟前
【Task02】:四步构建简单rag(第一章3节)
android·java·数据库
····懂···1 小时前
攻克PostgreSQL专家认证
数据库·postgresql
每天都在想吃啥1 小时前
day31 SQLITE
数据库·sqlite
m0_748254094 小时前
2025最新华为云国际版注册图文流程-不用绑定海外信用卡注册
服务器·数据库·华为云
大新屋4 小时前
MongoDB 分片集群修改管理员密码
数据库·mongodb
ejinxian5 小时前
MySQL/Kafka数据集成同步,增量同步及全量同步
数据库·mysql·kafka
未来之窗软件服务5 小时前
数据库优化提速(一)之进销存库存管理—仙盟创梦IDE
数据库·sql·数据库调优
Mapmost5 小时前
信创浪潮下的GIS技术变革:从自主可控到生态繁荣
数据库
foundbug9996 小时前
Node.js导入MongoDB具体操作
数据库·mongodb·node.js
天天进步20156 小时前
Node.js中的Prisma应用:现代数据库开发的最佳实践
数据库·node.js·数据库开发