| -- 添加标准身份证字段begin
 begin
 if not exists (select * from syscolumns where id=object_id('a_idcard') and)
 alter table a_idcard add [card] varchar(20);
 end
 -- 添加校验结果字段
 begin
 if not exists (select * from syscolumns where id=object_id('a_idcard') and)
 alter table a_idcard add [result] nvarchar(20);
 end
 end
 go
 --遍历结果BEGIN
 declare @id_card varchar(100), @res varchar(200),@c_index int
 declare cur cursor
 for select idcard from a_idcard -- 这里需要替换
 open curfetch next from cur into @id_card
 while @@FETCH_STATUS = 0
 begin
 set @res = dbo.fun_utils_idnumberoprater(@id_card)
 set @c_index = charindex('_',@res)
 print substring(@res,0,@c_index)
 print substring(@res, @c_index+1, len(@res))
 -- 这里需要替换update a_idcard set card=substring(@res, @c_index+1, len(@res)),result=substring(@res,0,@c_index)
 where idcard=@id_card
 fetch next from cur into @id_cardend
 close cur
 deallocate cur
 end
 go
 PS:下面看下身份证合法性校验模板 //这个可以验证15位和18位的身份证,并且包含生日和校验位的验证。 //如果有兴趣,还可以加上身份证所在地的验证,就是前6位有些数字合法有些数字不合法。
 function isIdCardNo(num) {
 if(num.indexOf("x")!=-1){
 return false;
 }
 num = num.toUpperCase();//身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
 if (!(/(^d{15}$)|(^d{17}([0-9]|X)$)/.test(num))) {
 alert('输入的身份证号长度不对,或者号码不符合规定!n15位号码应全为数字,18位号码末位可以为数字或X。');
 return false;
 }
 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
 //下面分别分析出生日期和校验位
 var len, re;
 len = num.length;
 if (len == 15) {
 re = new RegExp(/^(d{6})(d{2})(d{2})(d{2})(d{3})$/);
 var arrSplit = num.match(re);
 //检查生日日期是否正确
 var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]);
 var bGoodDay;
 bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2]))
 && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3]))
 && (dtmBirth.getDate() == Number(arrSplit[4]));
 if (!bGoodDay) {
 alert('输入的身份证号里出生日期不对!');
 return false;
 } else {
 //将15位身份证转成18位
 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
 var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
 var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
 var nTemp = 0, i;
 num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6);
 for (i = 0; i < 17; i++) {
 nTemp += num.substr(i, 1) * arrInt[i];
 }
 num += arrCh[nTemp % 11];
 return num;
 }
 }
 if (len == 18) {
 re = new RegExp(/^(d{6})(d{4})(d{2})(d{2})(d{3})([0-9]|X)$/);
 var arrSplit = num.match(re);
 //检查生日日期是否正确
 var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
 var bGoodDay;
 bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2]))
 && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3]))
 && (dtmBirth.getDate() == Number(arrSplit[4]));
 if (!bGoodDay) {
 alert(dtmBirth.getYear());
 alert(arrSplit[2]);
 alert('输入的身份证号里出生日期不对!');
 return false;
 } else {
 //检验18位身份证的校验码是否正确。
 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
 var valnum;
 var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
 var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
 var nTemp = 0, i;
 for (i = 0; i < 17; i++) {
 nTemp += num.substr(i, 1) * arrInt[i];
 }
 valnum = arrCh[nTemp % 11];
 if (valnum != num.substr(17, 1)) {
 alert('18位身份证的校验码不正确!应该为:' + valnum);
 return false;
 }
 return num;
 }
 }
 return false;
 }
 总结 到此这篇关于SqlServer2000+ 身份证合法校验函数的示例代码的文章就介绍到这了,更多相关sqlserver2000身份证校验内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! (编辑:宣城站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |