当前位置:  开发笔记 > 编程语言 > 正文

在存储过程中使用三态参数

如何解决《在存储过程中使用三态参数》经验,为你挑选了1个好方法。

这样做的正确方法是什么?例如,如何使用此签名更改存储过程:

CREATE PROCEDURE dbo.MyProcedure
  @Param BIT = NULL
AS
  SELECT *
  FROM dbo.SomeTable T
  WHERE T.SomeColumn = @Param

为@Param赋值1或0执行过滤器,但不指定它或传递NULL不执行过滤?



1> tvanfosson..:

假设NULL表示"不关心",则使用

CREATE PROCEDURE dbo.MyProcedure 
   @Param BIT = NULL
AS
   SELECT *
   FROM dbo.SomeTable T
   WHERE T.SomeColumn = @Param OR @Param IS NULL

推荐阅读
低调pasta_730
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有