首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Server计算列(如果值为负数则为0)

Server计算列(如果值为负数则为0)
EN

Stack Overflow用户
提问于 2018-03-07 04:53:40
回答 2查看 2.2K关注 0票数 0

我有一个计算出来的SQL Server列,计算方法如下:

代码语言:javascript
运行
复制
Number1 - Number2

如果恰好这个数学等于一个负数,我希望字段中有一个0值,而不是一个负数。

IE: 5-10 = -5 (显示0)或只显示正数.

代码语言:javascript
运行
复制
SELECT 
    CASE 
       WHEN [Scheduled] - [Purchased] < 0 
          THEN 0 
          ELSE [Scheduled] - [Purchased] 
    END

SELECT 
    IIF([Scheduled] - [Purchased] < 0, 0, [Scheduled] - [Purchased])
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-03-07 05:01:37

为此使用CASE

代码语言:javascript
运行
复制
SELECT CASE WHEN Scheduled - Purchased < 0 THEN 0 ELSE Scheduled - Purchased END

如果用作计算列,只需编写:

代码语言:javascript
运行
复制
CASE WHEN Scheduled - Purchased < 0 THEN 0 ELSE Scheduled - Purchased END

Server 2012之后,还可以使用IIF函数:

代码语言:javascript
运行
复制
SELECT IIF(Scheduled - Purchased < 0, 0, Scheduled - Purchased)
票数 3
EN

Stack Overflow用户

发布于 2018-03-07 04:58:20

您必须在这里使用sql和if or语句,尝试使用下面的statem、ents或refere 这篇文章

代码语言:javascript
运行
复制
IF value < 0 PRINT '0'  
ELSE PRINT 'value' ;  
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49144393

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档