CREATE FUNCTION sfzyz(inum varchar(18))
RETURNS varchar(18)
------------------------------------------------------------------------
-- 功能:输入18位身份证号码进行验证,15位自动转换成18位
-- 例如:sfzyz('412832197901086418')
------------------------------------------------------------------------
F1: BEGIN ATOMIC
--定义中间参量
declare i18 varchar(1) default '';
declare n int default 0;
declare l int default 0;
--算法
set l=length(inum);
if l=18 then
set n=int(substr(inum,1,1))*7+int(substr(inum,2,1))*9+int(substr(inum,3,1))*10+int(substr(inum,4,1))*5+int(substr(inum,5,1))*8+int(substr(inum,6,1))*4;
set n=n+int(substr(inum,7,1))*2+int(substr(inum,8,1))*1+int(substr(inum,9,1))*6+int(substr(inum,10,1))*3+int(substr(inum,11,1))*7+int(substr(inum,12,1))*9+int(substr(inum,13,1))*10+int(substr(inum,14,1))*5;
set n=n+int(substr(inum,15,1))*8+int(substr(inum,16,1))*4+int(substr(inum,1

这篇博客介绍了一个DB2的存储过程,用于验证18位身份证号码的合法性,15位号码会自动转换为18位。通过一系列算法计算校验码并与输入号码的最后一位进行对比,确保身份证号码的正确性。
最低0.47元/天 解锁文章
3469

被折叠的 条评论
为什么被折叠?



