SQL 中身份证编码与出生日期验证

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL 中身份证编码与出生日期验证相关的知识,希望对你有一定的参考价值。

哪位朋友能做一个SQL中能查询身份证编码与出生日期验证的语句,先谢谢了

参考技术A 根据身份证号验证出生日期:

alter table 你的表--修改表
/*添加约束 要么删掉你之前的生日约束 要么把
约束开始到结束复制到你的约束里再改*/
add constraint CK_生日 check(

--约束开始
convert(datetime,replace(stuff(stuff(right (left(char之类类型的18位的身份证号,14),8),5,0,'-'),8,0,'-'),'0',''))=生日字段
--约束结束

)

最后只要把中文替换掉就可以了本回答被提问者采纳
参考技术B 用正则

js 精确验证身份证(地址编码出生日期校验位验证)

//身份证号合法性验证 
//支持15位和18位身份证号
//支持地址编码、出生日期、校验位验证
        function IdentityCodeValid(code) { 
            var city={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江 ",31:"上海",32:"江苏",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北 ",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川",52:"贵州",53:"云南",54:"西藏 ",61:"陕西",62:"甘肃",63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外 "};
            var tip = "";
            var pass= true;
            //验证身份证格式(6个地区编码,8位出生日期,3位顺序号,1位校验位)
            if(!code || !/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[12])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i.test(code)){
                tip = "身份证号格式错误";
                pass = false;
            }
            
           else if(!city[code.substr(0,2)]){
                tip = "地址编码错误";
                pass = false;
            }
            else{
                //18位身份证需要验证最后一位校验位
                if(code.length == 18){
                    code = code.split(‘‘);
                    //∑(ai×Wi)(mod 11)
                    //加权因子
                    var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
                    //校验位
                    var parity = [ 1, 0, X, 9, 8, 7, 6, 5, 4, 3, 2 ];
                    var sum = 0;
                    var ai = 0;
                    var wi = 0;
                    for (var i = 0; i < 17; i++)
                    {
                        ai = code[i];
                        wi = factor[i];
                        sum += ai * wi;
                    }
                    var last = parity[sum % 11];
                    if(parity[sum % 11] != code[17]){
                        tip = "校验位错误";
                        pass =false;
                    }
                }
            }
            if(!pass) alert(tip);
            return pass;
        }

 

使用这个方法,把身份证号码传进去。就可以判断你的身份证是否合法了。

var c = ‘130981199312253466‘;//这个是待验证的身份证号码
var res= IdentityCodeValid(c);//这里是调用验证的方法


以上是关于SQL 中身份证编码与出生日期验证的主要内容,如果未能解决你的问题,请参考以下文章

sql从身份证中取出出生日期

身份证件号的验证与更改

java 验证身份证号

sql 从身份证中自动获取出生日期,显示格式为XXXX-XX-XX

SQL由身份证号计算出生日期和年龄

sql中,根据身份证号码截取出了出生日期,怎么获取当前年龄,精确到月、日?