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;

测试结果:

相关推荐
imuliuliang13 分钟前
MySQL的底层原理与架构
数据库·mysql·架构
尽兴-19 分钟前
Redis7 底层数据结构解析
数据结构·数据库·缓存·redis7
m0_7301151128 分钟前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
qq_4101942933 分钟前
SQL语句性能优化
数据库·sql·性能优化
小江的记录本1 小时前
【MyBatis-Plus】Spring Boot + MyBatis-Plus 进行各种数据库操作(附完整 CRUD 项目代码示例)
java·前端·数据库·spring boot·后端·sql·mybatis
wanhengidc1 小时前
《三国志异闻录》搬砖新游戏 云手机
运维·服务器·数据库·游戏·智能手机
2301_807367191 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
2301_795741791 小时前
构建一个基于命令行的待办事项应用
jvm·数据库·python
FITA阿泽要努力2 小时前
《实战SQL: GROUP BY》
数据库·sql
sw1213892 小时前
Python字典与集合:高效数据管理的艺术
jvm·数据库·python