身份证号验证算法(一) 18身份证号结构公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码+八位数字出生日期码+三位数字顺序码+一位校验码。 1、地址码表示编码对象常住户口所在县(市、旗、区)的行政区域划分代码,按GB/T2260的规定执行。 2、出生日期码表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。 3、顺序码表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。 4、校验码计算步骤(1)十七位数字本体码加权求和公式S = Sum(Ai * Wi),i = 0, ... , 16 ,先对前17位数字的权求和Ai:表示第i位置上的身份证号码数字值(0~9) Wi:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 (表示第i位置上的加权因子,计算的逻辑:第i位对应的数为[2^(18-i)]mod11) (2)计算模Y = mod(S, 11) (3)根据模,查找得到对应的校验码Y: 0 1 2 3 4 5 6 7 8 9 10校验码: 1 0 X 9 8 7 6 5 4 3 2 (二)说明1.程序可以根据已有的17位数字本体码,获取对应的验证码。 2.该程序可以剔除验证码不正确的身份证号码。 3.15位的身份证出生年份采用年份后2位,没有最后1位校验码。 4.完整的身份证18位,最后一位校验位可能是非数字。
SQL存储过程身份证号验证详细算法
相关推荐
Oracle身份证号检验函数
在Oracle数据库中,您可以使用以下SQL函数来检查身份证号的合法性:SELECT fn_checkidcard('身份证号') AS result FROM dual; 如果返回结果为1,则表示身份证号合法;如果返回结果为0,则表示身份证号非法。
Oracle
0
2024-08-03
身份证号地区数据库生成指南
在此数据库中,我们将身份证号段与对应的省份、城市、区镇等信息进行关联。通过使用INSERT INTO语句,可以轻松地将数据插入表格,示例如下:
INSERT INTO card_info (provinceID, cityID, regionID, province, city, region) VALUES (13, 130524, '河北省', '邢台市', '柏乡县');
此结构方便数据存储,能够有效匹配身份证号码段与地理位置,最终形成可执行的数据库结构。所有证件号码段均可在本表中对应其所属的行政区域,便于管理和查询。
SQLServer
0
2024-10-29
身份证位数升级
将 15 位身份证升级为 18 位
Oracle
2
2024-05-29
身份证城市代码查询SQL
身份证号码的前6位代码代表着所在城市的范围,用户可以通过这些代码分析身份证所属城市的信息。例如,370781代表青州市,即山东省潍坊市的一个县级市。这样一来,我们可以根据身份证号的前6位代码准确获取所在城市的详细信息。
MySQL
3
2024-07-25
身份证籍贯代码汇总
这是一个身份证籍贯代码的集合,可用于身份证籍贯识别。使用Excel中的VLOOKUP函数即可操作,涵盖中国所有地区。
MySQL
3
2024-07-16
PostgreSQL获取身份证校验码
创建自定义函数,输入身份证号码,获得对应的校验码。
PostgreSQL
3
2024-05-01
身份证地区代码详解及其含义
身份证号码的前六位数字代表了持证人的户籍所在地信息,这些代码具体标识了不同省市区的地理分布和管理区划。详细了解这些地区代码可以帮助人们更好地理解和利用身份证信息。
数据挖掘
0
2024-08-26
fn_checksfz-身份证校验函数
oracle身份证校验函数
Oracle
0
2024-11-04
使用Matlab实现身份证识别的模板匹配算法
随着技术进步,基于模板匹配算法的Matlab应用正在身份证识别领域展现其独特优势。
Matlab
2
2024-07-28