SQL Server 2008 R2:准备动态WHERE子句
发布时间:2021-03-02 14:14:34 所属栏目: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 – 如何在Rails中创建“即将到来的生日”模块?
- IE侵犯他人知识产权? 微软遭Eolas12亿美元索赔
- 如何在没有matlabs数据库工具箱的情况下从matlab访问postgr
- SQL Server误区:CheckPoint只会将已提交的事务写入磁盘
- sql-server – SQL Server如何确定缺失索引请求中的键列顺序
- 精英L4VXA2主板——P4X400芯片组的强势之作
- sql-server – 加速没有子句的巨大DELETE FROM的方法
- SQL SERVER – 按n分钟间隔对记录进行分组
- sql-server – SQL Server注入 – 26个字符中有多少损坏?


