在存儲過程中,使用變量存儲Sql where條件

静心尽力 2015-12-28 04:30:26
Dear All
在一個存儲過程中
declare conditioin varchar(10) ='1=1'
if isnull( @Para,'')<>' '
conditioin = ' T.a>0' --定義變量接收where條件語句

select a,b,c,d from TableA T1 inner join TableB T2 T1.a=T2.a
---------

where B>2 and 想條件不為空 就執行Sql條件,這裡不知道怎麼寫了
求指教


...全文
75 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhll2046 2015-12-28
  • 打赏
  • 举报
回复
在第二个where 条件使用case when

select   a,b,c,d from TableA T1  inner join TableB  T2  T1.a=T2.a 
            where B>2  
			And T.a > CASE WHEN isnull( @Para,'')<>' ' THEN 0  --如果@Para = ' ', 则 t.a>0
			   		ELSE T.a-1 END --t.a 恒大于t.a-1, 相当于上面的1=1


--对边下面2组结果
;with cte(n) as
(
select 2 union all select 0
)
select n from cte where n>case when 2=1 then 0 else n-1 end


;with cte(n) as
(
select 2 union all select 0
)
select n from cte where n>case when 1=1 then 1 else n-1 end

34,838

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧