admin

在存储过程中获取if / else错误

sql

我对SQL查询来说是一个相对较新的人,但是我有一个存储过程,在这里我试图获取声明的变量的值,如下所述,但出现错误,

第一行是20

declare @m_ID_v int
set @m_ID_v = ( select ID_C from M_T where MName_C = @MName_parameter)

declare @g bit
if (select G_L_Column from G_L_table Where M_ID_Column = @M_ID_variable)
    set @g_v = 1
else
    set @g_variable = 0

我得到的异常:

消息4145,级别15,状态1,过程GetID,第20行在“
条件”附近的“设置”附近指定了非布尔类型的表达式。消息156,级别15,状态1,过程GetID,第21行关键字’else’附近的语法错误。

现在,如果我删除declare @g...并尝试对其进行分析,则不会发生任何错误

编辑

我希望我的代码通过我的select语句检查返回的值,所以对不起,“如果存在”不是真正要查找的内容。


阅读 127

收藏
2021-06-07

共1个答案

admin

declare @m_ID_v int
set @m_ID_v = ( select ID_C from M_T where MName_C = @MName_parameter)

declare @g bit
if ((select G_L_Column from G_L_table Where M_ID_Column = @M_ID_variable) = value )
    set @g_v = 1
else
    set @g_variable = 0
2021-06-07