SQL 2008存储过程中的可选where子句/参数?

lar*_*ryq 4 sql sql-server stored-procedures optional-parameters sql-server-2008

我正在写一些更新表的代码.根据用户想要做的事情,它可以更新大量记录,也可以更小.描绘因子是组ID.

用户可以选择是更新所有记录的表,还是仅更新具有该groupID的记录.我想对两个实例使用相同的存储过程,可能有一点逻辑来区分这些场景.(我不想用90%相同的代码编写两个存储过程.)

我不是存储过程的专家,我不确定是否可以传入可选参数,或者如何动态生成where子句的一部分,具体取决于groupID是否存在.欢迎任何建议.

谢谢!

gbn*_*gbn 11

您可以使用此或"OR"结构

... WHERE GroupID = ISNULL(@GroupdID, GroupID)


... WHERE GroupID = @GroupdID OR @GroupdID IS NULL
Run Code Online (Sandbox Code Playgroud)