SQL SERVER性能问题

SQL如下:

declare @num int 

set @num='类型'

select * from A01 where '类型'=@num

union all 

select * from A01 where '类型A' = @num

union all 

select * from A01 where '类型B' = @num

问题:请问传参只有第一条select满足条件,第二条跟第三条还会重复执行吗?如果重复执行的话该怎么优化?

 

Int 类型的变量你赋值字符串? select * from A01 where ('类型'=@num or '类型a'=@num or '类型b'=@num)

会,优化: 程序提前判断,然后决定走哪条sql分支. 或者用case when

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y