使用SQL对身份证合法性检验
来源:互联网 发布:java supplier 接口 编辑:程序博客网 时间:2024/05/16 23:37
不多说 直接代码
USE [xd]
GO
/****** Object: UserDefinedFunction [dbo].[IsvalidIDCard] Script Date: 04/24/2013 16:37:50 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER FUNCTION [dbo].[IsvalidIDCard](@IDCardNo varchar(18))
RETURNS bit
AS
/*******************************************************************
函数名称:udf_IsvalidIDCard()
参数:@IDCardNo string 身份证号码
返回值: bit 是否有效
功能描述:判断身份证号码是否合法
备注:目前中国的身份证号码有18位和15位.
1,18位身份证号码的组成:6位地区编码+8位出生年月日+3位编号(奇男偶女)+1位校验码
2,15位身份证号码的组成:6位地区编码+6位出生年月日+3位编号(奇男偶女)
*******************************************************************/
BEGIN
declare @Length int,
@Loop int,
@Sum int
declare @SingleChar char
set @Sum = 0
if @IDCardNo is null or @IDCardNo = null or ltrim(rtrim(@IDCardNo)) = ''
begin
return 0
end
set @Length = len(@IDCardNo)
--判断位数
if @Length < > 18 and @Length < > 15
begin
return 0
end
if @Length = 18
begin
if isnumeric(left(@IDCardNo, 17)) = 0
begin
return 0
end
if isdate(substring(@IDCardNo, 7, 4) + '-' + substring(@IDCardNo, 11, 2) + '-' + substring(@IDCardNo, 13, 2)) = 0
begin
return 0
end
set @Loop = 17
while (@Loop >= 1)
begin
set @Sum = @Sum + convert(int,substring(@IDCardNo, @Loop, 1)) * (power(2,(18 - @Loop)) % 11)
set @Loop = @Loop - 1
end
set @Loop = @Sum % 11
if @Loop = 0
begin
set @SingleChar = '1'
end
else if @Loop = 1
begin
set @SingleChar = '0'
end
else if @Loop = 2
begin
set @SingleChar = 'X'
end
else
begin
set @SingleChar = convert(varchar(2),(12 - @Loop))
end
if lower(Right(@IDCardNo, 1)) < > lower(@SingleChar)
begin
return 0
end
end
else if @Length = 15
begin
if isnumeric(@IDCardNo) = 0
begin
return 0
end
if isdate('19' + substring(@IDCardNo, 7, 2) + '-' + substring(@IDCardNo, 9, 2) + '-' + substring(@IDCardNo, 11, 2)) = 0
begin
return 0
end
end
return 1
END
- 使用SQL对身份证合法性检验
- SQL Server 验证身份证合法性函数(使用VBScript.RegExp)
- 一个检验身份证合法性用PLSQL实现的方法
- 【身份证合法性检查程序】(计算最后一位检验码)
- 一个检验身份证合法性用PLSQL实现的方法.txt
- 检验身份证号码的合法性
- js 验证身份证合法性
- java 《判断身份证合法性》
- java身份证合法性校验
- java身份证合法性校验
- 身份证验证合法性
- 验证身份证的合法性
- java身份证合法性校验
- java身份证合法性校验
- Java验证身份证合法性
- 使用Ajax对用户合法性做判断
- PHP检验身份证代码
- 身份证检验信息
- httpInvoker提供远程服务调用总结(三)
- 找出最长的有效的Parentheses
- C++ TinyXML 解析器
- 利用WinSock2 SPI进行网络内容访问控制
- HDOJ 1865 1sting 13.04.21 周赛结题报告 (大数加法)
- 使用SQL对身份证合法性检验
- 黑马程序员_解决读取web.xml中文字符乱码问题
- android-async-http
- 操作符重载
- dup和dup2函数
- js自定义对象
- ArcEngine 图层标注 (根据字段、角度)
- 串口调试
- HDU1756(判断点在多边形内外)