如何判断存储过程变量的值是否为空?

发布于 2022-09-06 21:38:18 字数 936 浏览 20 评论 0

如何判断存储过程变量的值是否为空?主要判断员工的字段输入值是否为空,我在另外一个表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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

野の 2022-09-13 21:38:18

很明显没有值传过来啊

做一个判断是否为空然后赋默认值

解决

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文