如何判断存储过程变量的值是否为空?
如何判断存储过程变量的值是否为空?主要判断员工的字段输入值是否为空,我在另外一个表CMSFIE里定义了哪些字段可以为空哪些字段不能为空,然后在员工资料的保存中取这个字段的值来和CMSFIE中存储的是否为空标志进行比对;
模拟过程如下:
create proc myepatest
@EPA002 varchar(10), --员工信息字段
@EPA003 varchar(80), --员工信息字段
@EPA004 varchar(40) --员工信息字段
as
declare @R varchar(1000)
declare @fieldname varchar(10) --CMSFIE表中存储的字段名
declare @nsql nvarchar(1000)
declare mycursor cursor for
select (substring(FIE003,1,6)) Field from CMSFIE where FIE002='vCMSEPA' and FIE019='1' //从CMSFIE表中读出必填字段名
open mycursor
fetch next from mycursor into @fieldname
while (@@FETCH_STATUS=0)
begin
set @nsql='if (@'+@fieldname+'='''') or (@'+@fieldname+' is null) set @R=''x'' else set @R= ''y'' '
EXEC(@nSQL)
fetch next from mycursor into @fieldname
end
close mycursor
deallocate mycursor
---执行时报错 @EPA002,@EPA003 ,@R变量没有定义
该如何定义
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
很明显没有值传过来啊
做一个判断是否为空然后赋默认值
解决