贷款卡编码一共有16位,最后两位是校验位
整个贷款卡编码的规则如下:
前三位:分别为数字或者大写英文字母
第四位到第十四位:分别为数字
后两位的校验码为
前十四位乘以权重相加后除以97后的余数再加1后得到的数字,
如果此数字为个位数,前面还需要补一个零
前十四位编码对应的权重为1,3,5,7,11,2,13,1,1,17,19,97,23,29
如果某一位为字母,则需要将此字母转换为数字,A转为为10,B转为为11,以此类推。
Excel校验举例
如果B6为贷款卡编码的填写单元格,则在B7填写以下公式即可
=if(LEN(B6)<>16,"贷款卡编码必须为16位", if(RIGHT(CONCATENATE("0",1+MOD(SUM((FIND(MID(B6,{1,2,3},1),"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ")-1)*{1,3,5})+
SUM((FIND(MID(B6,{4,5,6,7,8,9,10,11,12,13,14},1),"0123456789")-1)*{7,11,2,13,1,1,17,19,97,23,29}),97)),2)=MID(B6,15,2),"", "贷款卡编码校验码错误"))
存储过程校验举例
略