微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

您可以使用此或“或”构造

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


... WHERE GroupID = @GroupdID OR @GroupdID IS NULL

解决方法

我正在编写一些更新表的代码。根据用户想要执行的操作,它会更新大量的记录,也可能更新较小的记录。描绘因素是组ID。

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

我不是存储过程的专家,也不知道是否可以传入可选参数,或者如何根据groupID是否存在来动态生成where子句的一部分。欢迎任何建议。

谢谢!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。