首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >比较2列并返回SQL中的文本

比较2列并返回SQL中的文本
EN

Stack Overflow用户
提问于 2022-03-31 06:26:36
回答 1查看 47关注 0票数 0

我想在传递状态值之后比较金额和最后金额值。(现在硬编码)

代码语言:javascript
复制
if amount > Lastamount ='up',
if amount < Lastamount ='down'
if amount == Lastamount ='equal'

我的存储过程

代码语言:javascript
复制
ALTER PROC my
    @Year int = NULL,
    @Quarter int = NULL,
    @Month int = NULL
AS 
BEGIN 
    SELECT 'ASO' AS Name
        , 'Active Serviced Outlets' AS Description
        , 'up' AS status
        , CAST(COUNT(DISTINCT Outlet)/1.0 AS DECIMAL(9,2)) AS Amount    
        , (
            SELECT CAST(COUNT(DISTINCT Outlet)/1.0 AS DECIMAL(9,2)) AS Amount
            FROM SalesAndReturns_RPT
            WHERE ((Call_ActualStartDate >= DATEFROMPARTS(@Year, 1, 1) 
            AND Call_ActualStartDate < DATEFROMPARTS(@Year+1, 1, 1)) OR @Year IS NULL)
            AND (DATEPART(QUARTER, Call_ActualStartDate) = @Quarter OR @Quarter IS NULL)
            AND (DATEPART(MONTH,Call_ActualStartDate) = @Month OR @Month IS NULL)
        ) AS LastAmount
    FROM SalesAndReturns_RPT
    WHERE ((Call_ActualStartDate >= DATEFROMPARTS(@Year-1, 1, 1)
    AND Call_ActualStartDate < DATEFROMPARTS(@Year , 1, 1)) OR @Year IS NULL)
    AND (DATEPART(QUARTER, Call_ActualStartDate) = @Quarter OR @Quarter IS NULL)
    AND (DATEPART(MONTH,Call_ActualStartDate) = @Month OR @Month IS NULL)
    OPTION (RECOMPILE);
END

过程输出

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-31 06:46:50

我想您只是想使用CASE表达式来比较LastAmount的数量,使用子查询或CTE。

代码语言:javascript
复制
WITH cte AS (
    SELECT 'ASO' AS Name
        , 'Active Serviced Outlets' AS Description
        -- , 'up' AS status
        , CAST(COUNT(DISTINCT Outlet)/1.0 AS DECIMAL(9,2)) AS Amount    
        , (
            SELECT CAST(COUNT(DISTINCT Outlet)/1.0 AS DECIMAL(9,2)) AS Amount
            FROM SalesAndReturns_RPT
            WHERE ((Call_ActualStartDate >= DATEFROMPARTS(@Year, 1, 1) 
            AND Call_ActualStartDate < DATEFROMPARTS(@Year+1, 1, 1)) OR @Year IS NULL)
            AND (DATEPART(QUARTER, Call_ActualStartDate) = @Quarter OR @Quarter IS NULL)
            AND (DATEPART(MONTH,Call_ActualStartDate) = @Month OR @Month IS NULL)
        ) AS LastAmount
    FROM SalesAndReturns_RPT
    WHERE ((Call_ActualStartDate >= DATEFROMPARTS(@Year-1, 1, 1)
    AND Call_ActualStartDate < DATEFROMPARTS(@Year , 1, 1)) OR @Year IS NULL)
    AND (DATEPART(QUARTER, Call_ActualStartDate) = @Quarter OR @Quarter IS NULL)
    AND (DATEPART(MONTH,Call_ActualStartDate) = @Month OR @Month IS NULL)
)
SELECT *
    , CASE WHEN Amount > Lastamount THEN 'up' WHEN Amount < Lastamount THEN 'down' ELSE 'equal' END
FROM cte
OPTION (RECOMPILE);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71687818

复制
相关文章

相似问题

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