oracle关于15位身份证转换18位身份证函数

近期由于业务系统历史数据的原因存在大量15位的身份证,需要转换成18位的身份证,15是2000年之前的身份证,之后的就没有15位了。

在网上找了一些函数,可以正常应用,函数如下:

复制代码
Create Or Replace Function IDCARD15TO18(CARD Varchar2) Return Varchar2 Is
  Type TIARRAY Is Table Of Integer;
  Type TCARRAY Is Table Of Char(1);
  RESULTS Varchar2(18);
  W       TIARRAY; -- 数字数组
  A       TCARRAY; -- 字符数组
  S       Integer;
Begin
  If CARD Is Null Then
    Return '';
  End If;
  If LENGTH(CARD) <> 15 Then
    Return CARD;
  End If;
  W       := TIARRAY(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1);
  A       := TCARRAY('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
  RESULTS := SUBSTR(CARD, 1, 6) || '19' || SUBSTR(CARD, 7, 9);
  S       := 0;
  Begin
    For I In 1 .. 17 Loop
      S := S + To_Number(SUBSTR(RESULTS, I, 1)) * W(I);
    End Loop;
  Exception
    When Others Then
      Return '';
  End;
  S       := S Mod 11;
  RESULTS := RESULTS || A(S + 1);
  Return(RESULTS);
End IDCARD15TO18;
复制代码

create table dw11 (sfz varchar2(18));
insert into dw11 values ('320122880110323');

select IDCARD15TO18(sfz) from dw11;

update  dw11 set sfz=IDCARD15TO18(sfz);

commit;即可将身份证转换成18位的身份证了。

posted on   小杜的学习天地  阅读(1768)  评论(0编辑  收藏  举报

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示