好问题
Good  Question
  • 首 页
  • 问题
    • PHP
    • JAVA
    • CPlusPlus
    • C#
    • SQL
  • 关 于
  • 联 系
如何SQL语句中使用IF…THEN? 关闭 返回上一级  

如何SQL语句中使用IF…THEN?
+ 查看更多

发布日期:2018-02-24 16:57
分类:SQL
浏览次数:98

如何在一个SELECT语句中使用IF…THEN结构呢?

例如:

SELECT IF(Obsolete = 'N' OR InStock = 'Y' ? 1 : 0) AS Saleable, * FROM Product

回答

SQL中的CASE语句最接近IF结构,并且所有版本的SQL Server都支持。
SELECT CAST(
             CASE 
                  WHEN Obsolete = 'N' or InStock = 'Y' 
                     THEN 1 
                  ELSE 0 
             END AS bit) as Saleable, * 
FROM Product
CAST语句可以返回布尔类型的结果,如果只需要返回int型,可以这样做:
SELECT CASE 
            WHEN Obsolete = 'N' or InStock = 'Y' 
               THEN 1 
               ELSE 0 
       END as Saleable, * 
FROM Product
CASE语句可以被嵌套在其他的CASE语句中,甚至可以包含在聚合中。
SQL Server Denali(SQL Server 2012)添加了一个IIF语句,它也可以在access中使用:
SELECT IIF(Obsolete = 'N' or InStock = 'Y', 1, 0) as Saleable, * FROM Product
上一篇插入...值(SELECT ... FROM ...)
如何删除重复的行?下一篇
下一篇如何删除重复的行?

最新文章

  • 函数`__construct`用来干嘛的
    发布日期:2018-03-26
  • 通过访客的IP得到他们的地区
    发布日期:2018-03-26
  • 合并两个PHP对象的最好的方法是什么?
    发布日期:2018-03-26
  • 该如何把一该如何把一个对象转化成数组?
    发布日期:2018-03-26
  • 什么是输出缓冲区?
    发布日期:2018-03-26
  • 在PHP中怎么把用逗号分隔的字符串分隔在一个数组里?
    发布日期:2018-03-26
  • 在PHP中使用foreach循环时查找数组的最后一个元素
    发布日期:2018-03-26
关于好问
收集整理一些有用的问题和回答,造福中国的程序旺和IT喵们!
友情链接
起飞页 
相关信息
版权声明
Copyright © 2016 - 2022  苏州卡达网络科技有限公司 备案号:苏ICP备09008221号