设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2925|回复: 4
打印 上一主题 下一主题

[帮助] 身份证号验证问题

[复制链接]
跳转到指定楼层
1#
发表于 2013-6-30 23:16:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
有一字段是身份证号(18位),怎样把身份号不正确的记录查询出来。。
总共有1000个左右的记录
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
 楼主| 发表于 2013-6-30 23:55:06 | 只看该作者
找到如烟的的函数,验证通过。。

'函数名称: IsIDNumber
'功能描述: 根据GB11643-1999编码规则验证18位身份证号码是否有效
'输入参数: 参数1:IDNumber 必需的,18位身份证号码
'返回参数: 有效返回True,无效返回False
'兼 容 性:
'使用示例: IsIDNumber("370284197901130819") '返回True
'相关调用:
'作 者: 红尘如烟
'创建日期: 20010-4-25
'===================================================================
Function IsIDNumber(ByVal IDNumber As String) As Boolean
Const W As String = "79058421637905842" '加权因子
Const C As String = "10X98765432" '校验码
Dim S As Integer, i As Integer, T As Integer

IDNumber = UCase(Trim(IDNumber))
If Len(IDNumber) <> 18 Then Exit Function
If Not IsNumeric(Mid(IDNumber, 1, 17)) Then Exit Function
If Not IDNumber Like "*[0-9X]" Then Exit Function


For i = 1 To 17
    T = Mid(W, i, 1)
    If T = 0 Then T = 10
    S = S + Mid(IDNumber, i, 1) * T
Next
T = S Mod 11
If Right(IDNumber, 1) = Mid(C, T + 1, 1) Then IsIDNumber = True
End Function

3#
发表于 2013-7-1 10:01:14 | 只看该作者
怎么才叫不正确?18位?判断长度。len
4#
发表于 2013-7-1 12:46:17 | 只看该作者
查下身份证的编码规则,然后再根据条件判断是否不正确
5#
 楼主| 发表于 2013-7-1 12:49:30 | 只看该作者
已经用无烟的函数搞定了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-14 19:56 , Processed in 0.133521 second(s), 28 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表