数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
查询新身份证(18位)的校验位

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

/*
    根据〖中华人民共和国国家标准 GB 11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。

    地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码。生日期码表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。顺序码表示同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。顺序码的奇数分给男性,偶数分给女性。校验码是根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。下面举例说明该计算方法。 

    15位的身份证编码首先把出生年扩展为4位,简单的就是增加一个19,但是这对于1900年出生的人不使用(这样的寿星不多了)

    某男性公民身份号码本体码为34052419800101001,首先按照公式⑴计算:

∑(ai×Wi)(mod 11)……………………………………(1)

公式(1)中:
i----表示号码字符从由至左包括校验码在内的位置序号;
ai----表示第i位置上的号码字符值;
Wi----示第i位置上的加权因子,其数值依据公式Wi=2(n-1)(mod 11)计算得出。

i       18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1

ai       3  4  0  5  2  4  1  9  8  0  0  1  0  1  0  0  1 a1

Wi       7  9 10  5  8  4  2  1  6  3  7  9 10  5  8  4  2  1

ai×Wi  21 36  0 25 16 16  2  9 48  0  0  9  0  5  0  0  2 a1

根据公式(1)进行计算:

∑(ai×Wi) =(21+36+0+25+16+16+2+9+48++0+0+9+0+5+0+0+2) = 189

189 ÷ 11 = 17 + 2/11

∑(ai×Wi)(mod 11) = 2

    然后根据计算的结果,从下面的表中查出相应的校验码,其中X表示计算结果为10:

∑(ai×WI)(mod 11)   0 1 2 3 4 5 6 7 8 9 10
校验码字符值ai       1 0 X 9 8 7 6 5 4 3  2
    根据上表,查出计算结果为2的校验码为所以该人员的公民身份号码应该为 34052419800101001X。

 

a[0]*7+a[1]*9+a[2]*10+a[3]*5+a[4]*8+a[5]*4+a[6]*2+a[7]*1+a[8]*6+a[9]*3
+a[10]*7+a[11]*9+a[12]*10+a[13]*5+a[14]*8+a[15]*4+a[16]*2
%11

when 0 then '1' when 1 then '0' when 2 then 'X' when 3 then '9'
when 4 then '8' when 5 then '7' when 6 then '6' when 7 then '5'
when 8 then '4' when 9 then '3' when 10 then '2'

*/ 

 /*

以上为算法详细说明,下面是SQL的自定义函数,返回值为18位的校验码

*/
Create   function getCheckCode(@SFZH char(18))
Returns char(1)
As
Begin
 declare @r char(1)
 declare @i int
 if len(@SFZH) <> 18
  set @r = '?'
 else
  set @i = cast(substring(@SFZH,1,1) as int) * 7
   +cast(substring(@SFZH,2,1) as int) * 9
   +cast(substring(@SFZH,3,1) as int) * 10
   +cast(substring(@SFZH,4,1) as int) * 5
   +cast(substring(@SFZH,5,1) as int) * 8
   +cast(substring(@SFZH,6,1) as int) * 4
   +cast(substring(@SFZH,7,1) as int) * 2
   +cast(substring(@SFZH,8,1) as int) * 1
   +cast(substring(@SFZH,9,1) as int) * 6
   +cast(substring(@SFZH,10,1) as int) * 3
   +cast(substring(@SFZH,11,1) as int) * 7
   +cast(substring(@SFZH,12,1) as int) * 9
   +cast(substring(@SFZH,13,1) as int) * 10
   +cast(substring(@SFZH,14,1) as int) * 5
   +cast(substring(@SFZH,15,1) as int) * 8
   +cast(substring(@SFZH,16,1) as int) * 4  
   +cast(substring(@SFZH,17,1) as int) * 2
  set @i = @i - @i/11 * 11
 set @r = (case @i
   when 0 then '1' when 1 then '0' when 2 then 'X' when 3 then '9'
   when 4 then '8' when 5 then '7' when 6 then '6' when 7 then '5'
   when 8 then '4' when 9 then '3' when 10 then '2' else '/' end)
 Return(@r)
End

/*   Usage:
select dbo.getcheckcode('身份证号')

*/

 

 




相关文章

相关软件