内容简介:翻译自:https://stackoverflow.com/questions/414431/sql-case-expression-inside-where
我在这里阅读了有关在WHERE子句中使用CASE表达式的内容:
http://scottelkin.com/sql/using-a-case-statement-in-a-sql-where-clause/
我正在尝试使用它来根据用户应用程序传递的合同号来过滤select语句的结果.我的代码当前抛出了’无效参数’的错误,无论传入什么.我验证SELECT / FROM工作正常,如没有CASE表达式的WHERE子句.这是我的代码.
WHERE (CASE WHEN @ContractNo = 0 THEN @ContractNo ELSE @ContractNo END = tblContracts.ContractNo)
代码的冗余用于故障排除,我打算稍后在CASE上使用通配符过滤.我正专注于立即降低语法.我相信这应该返回参数与表中存储的合同号匹配的所有记录.任何帮助或建议将不胜感激.
阅读完解释后,如果没有CASE,有更好的方法:
WHERE @ContractNo = 0 OR tblContracts.ContractNo = @ContractNo
这将仅返回匹配的合同号,除非@ContractNo为0,在这种情况下,它将返回所有记录.
编辑:我刚注意到 casperOne proposed the same thing .我没有看到.大自己.
翻译自:https://stackoverflow.com/questions/414431/sql-case-expression-inside-where
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python编程快速上手
Albert Sweigart / 王海鹏 / 人民邮电出版社 / 2016-7-1 / 69.00元
如今,人们面临的大多数任务都可以通过编写计算机软件来完成。Python是一种解释型、面向对象、动态数据类型的高级程序设计语言。通过Python编程,我们能够解决现实生活中的很多任务。 本书是一本面向实践的Python编程实用指南。本书的目的,不仅是介绍Python语言的基础知识,而且还通过项目实践教会读者如何应用这些知识和技能。本书的首部分介绍了基本Python编程概念,第二部分介绍了一些不......一起来看看 《Python编程快速上手》 这本书的介绍吧!