SQL Server 2008 R2:准备动态WHERE子句
发布时间:2021-03-04 06:18:07 所属栏目:MsSql教程 来源:网络整理
导读:我有以下四个参数的存储过程. 存储过程spTest: CREATE PROCEDURE spTest @Name varchar(20) = '',@Address varchar(100) = '',@City varchar(50) = '',@Pin varchar(50) = ''AS DECLARE @DynamicWhere varchar(max) DECLARE @Query varchar(max) /* Here
我有以下四个参数的存储过程. 存储过程spTest: CREATE PROCEDURE spTest @Name varchar(20) = '',@Address varchar(100) = '',@City varchar(50) = '',@Pin varchar(50) = '' AS DECLARE @DynamicWhere varchar(max) DECLARE @Query varchar(max) /* Here I want to prepare a dynamic where clause for all possibilities */ SET @Query = 'SELECT * FROM Test_Table '+ @DynamicWhere +''; EXECUTE(@Query); GO 好吧,我正在准备这样: IF @Name = '' AND @Address = '' AND @City = '' AND @Pin = '' BEGIN SET @DynamicWhere = ''; END ELSE IF @Name != '' AND @Address = '' AND @City = '' AND @Pin = '' BEGIN SET @DynamicWhere = 'Name ='''+@Name+''''; END ELSE IF @Name != '' AND @Address != '' AND @City = '' AND @Pin = '' BEGIN SET @DynamicWhere = 'Name ='''+@Name+''' AND Address ='''+@Address+''''; END ...... ...... Many possibilities 这是正确的方法还是有更好的方法来准备动态WHERE子句? 解决方法它被称为catch-all查询,它基本上是这样的:CREATE PROCEDURE spTest @Name varchar(20) = '',@Pin varchar(50) = '' AS SELECT * FROM Test_Table WHERE (@Name = '' OR Name = @Name) AND (@Address = '' OR Address = @Address) AND (@City = '' OR City = @City) AND (@Pin = '' OR Pin = @Pin); GO 您也可以阅读this article about catch all queries (编辑:滁州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql-server – 为什么我需要两个SQL Server Service Broker
- sql-server-2008 – 与SQL Server分开安装Team Foundation
- data-structures – 关系数据库的高效持久数据结构
- sql-server-2012 – 没有数据的SQL Server 2012拷贝数据库
- 详解SQL Server的差异备份还原
- sql-server – 如何为单个存储过程授予执行权限?
- 在现有数据库中创建ASP.Net成员资格数据库结构
- 配置 SQL Server Email 发送以及 Job 的 Notification通知功
- 王码鼠标巧解汉字输入难题 去掉键盘单手操作
- ssf模拟器怎么用?