开发者社区> 问答> 正文

如何检查查询是否为 IF 条件内为空?

如何检查查询是否为 IF 条件内为空?

展开
收起
贺贺_ 2019-12-04 22:25:46 402 0
1 条回答
写回答
取消 提交回答
  • 在mysql中,您可以使用exist,就像

    SELECT  ContractID, ContractName,IF( EXISTS(
    SELECT 
        Count(SiteID)
    FROM ChartFace 
        INNER JOIN Structure ON Structure.StructureID = ChartFace.StructureID
    WHERE (ContractNumber='C197960' AND LineNumber=4) AND 
        (ISNULL('MN420628', '-1')='-1' or SiteID = 'MN420628')),'yes','No') Status 
    FROM Contract ;
    
    

    在SQL Server中:

    SELECT ContractID, ContractName,CASE
         WHEN EXISTS (SELECT 
        Count(SiteID)
    FROM ChartFace 
        INNER JOIN Structure ON Structure.StructureID = ChartFace.StructureID
    WHERE (ContractNumber='C197960' AND LineNumber=4) AND 
        (ISNULL('MN420628', '-1')='-1' or SiteID = 'MN420628')) THEN 'yes'
         ELSE 'NO'
       END as  Status 
    FROM Contract ;
    
    2019-12-04 22:27:25
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载