DB2 验证身份证的存储过程
来源:互联网 发布:java知名培训机构 编辑:程序博客网 时间:2024/06/06 12:38
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,17,1))*2;
set n=mod(n,11);
if n=0 then set i18='1';
elseif n=1 then set i18='0';
elseif n=2 then set i18='x';
elseif n=3 then set i18='9';
elseif n=4 then set i18='8';
elseif n=5 then set i18='7';
elseif n=6 then set i18='6';
elseif n=7 then set i18='5';
elseif n=8 then set i18='4';
elseif n=9 then set i18='3';
elseif n=10 then set i18='2';
end if;
if i18=substr(inum,18,1) then return inum;
else return 'number error';
end if;
elseif l=15 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+1*2+9*1+int(substr(inum,7,1))*6+int(substr(inum,8,1))*3+int(substr(inum,9,1))*7+int(substr(inum,10,1))*9+int(substr(inum,11,1))*10+int(substr(inum,12,1))*5;
set n=n+int(substr(inum,13,1))*8+int(substr(inum,14,1))*4+int(substr(inum,15,1))*2;
set n=mod(n,11);
if n=0 then return substr(inum,1,6)||'19'||substr(inum,7)||'1';
elseif n=1 then return substr(inum,1,6)||'19'||substr(inum,7)||'0';
elseif n=2 then return substr(inum,1,6)||'19'||substr(inum,7)||'x';
elseif n=3 then return substr(inum,1,6)||'19'||substr(inum,7)||'9';
elseif n=4 then return substr(inum,1,6)||'19'||substr(inum,7)||'8';
elseif n=5 then return substr(inum,1,6)||'19'||substr(inum,7)||'7';
elseif n=6 then return substr(inum,1,6)||'19'||substr(inum,7)||'6';
elseif n=7 then return substr(inum,1,6)||'19'||substr(inum,7)||'5';
elseif n=8 then return substr(inum,1,6)||'19'||substr(inum,7)||'4';
elseif n=9 then return substr(inum,1,6)||'19'||substr(inum,7)||'3';
elseif n=10 then return substr(inum,1,6)||'19'||substr(inum,7)||'2';
end if;
else return 'length error';
end if;
--RETURN date(rtrim(char(idate/10000))||'-'||rtrim(char(mod(idate,10000)/100))||'-'||rtrim(char(mod(idate,100))));
END
- DB2 验证身份证的存储过程
- DB2的存储过程
- DB2递归的存储过程!
- MYBATIS+DB2存储过程验证SQL语句正确性
- DB2存储过程调用另外存储过程的结果集
- DB2最基本的存储过程
- DB2存储过程(Merge关键字的使用)
- DB2下写的一个存储过程
- DB2存储过程的一些基础知识
- 一个很好的DB2存储过程例子
- DB2的几个存储过程实例
- java调用db2存储过程的例子
- 关于DB2存储过程的一点经验
- DB2 存储过程的异常处理器类型有几种?
- 记一次DB2存储过程的创建
- db2存储过程语法
- DB2存储过程
- DB2 存储过程 调试
- Test
- Exception_08
- 基于java的快速排序实现
- DataList+MySql+AspNetPager分页
- 今天,我开始新的生活!
- DB2 验证身份证的存储过程
- 10月杂想一
- 桂圆大枣红豆汤
- 面试日(阿里巴巴校园招聘第三日,复旦大学面试)
- Oracle安装-Linux内核参数-共享内存信号量设置
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- jvm详解
- 两年程序员生涯总结
- MapXtreme for Java精华文章资料荟萃