SQL身份证语句问题

执行出现如下问题,我的目的是从人员信息表中的IDC看身份证号是否正确。代码如下:CREATEFUNCTIONdbo.fun_IsValidID(@IDCVarchar(1... 执行出现如下问题,我的目的是从人员信息表中的IDC看身份证号是否正确。
代码如下:
CREATE FUNCTION dbo.fun_IsValidID(@IDC Varchar(18))
-- Add the parameters for the stored procedure here
RETURNS BIT
AS
BEGIN
DECLARE @Val@IDCFactors VARCHAR(17),
@Val@IDCCodes VARCHAR(11),
@I TINYINT,
@iTemp INT

--位数不满足则为非法@IDC

IF Len(@IDC) <> 15 AND Len(@IDC) <> 18
RETURN(0);

--如果是位身份证则只验证日期和是否数字格式
IF LEN(@IDC)=15
IF ISDATE('19'+SUBSTRING(@IDC,7,6))=0 OR @IDC NOT LIKE REPLICATE('[0-9]',15)
RETURN(0);
ELSE
RETURN(1);

/*18位身份证验证日期校验位*/

--验证日期和前位是否数字格式
IF ISDATE(SUBSTRING(@IDC,7,8))=0 OR LEFT(@IDC,17) NOT LIKE REPLICATE('[0-9]',17)
RETURN(0);

--验证校验位开始
SELECT @Val@IDCFactors='79A584216379A5842',
@Val@IDCCodes='10X98765432',
@I=1,@iTemp=0

WHILE @i<18
BEGIN
SELECT
@iTemp=@iTemp+CAST(SUBSTRING(@IDC,@i,1) AS INT)*(CASE SUBSTRING(@val@IDCFactors,@i,1) WHEN 'A' THEN 10 ELSE SUBSTRING(@Val@IDCFactors,@i,1) END)
,@i=@i+1
END

IF SUBSTRING(@Val@IDCCodes,@iTemp%11+1,1)=RIGHT(@IDC,1)
RETURN(1);
ELSE
RETURN(0);

RETURN NULL;
END
展开
 我来答
射手幽灵伊
2015-01-22 · TA获得超过2716个赞
知道大有可为答主
回答量:4955
采纳率:81%
帮助的人:1958万
展开全部
就是你已经创建过了。或是有同名的函数了。
如果你是修改此函数,使用alter function。
你可以在可编程里,打开函数,找到这个名字的函数,看看里面内容是什么。
更多追问追答
追问
我想找到执行后的结果,但不知道在哪里
追答

在对象资源管理器的树形结构里:

数据名称下,点开可编程性-->函数-->标量函数


推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式