首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查找不包括零的3个值中的最小值

查找不包括零的3个值中的最小值
EN

Stack Overflow用户
提问于 2011-06-30 19:38:39
回答 2查看 323关注 0票数 1

我正在寻找三列中最小的一列(Market, LiFo, Wgtd_Avg)。我可以这样做,但不包括等于零的三个值中的任何一个。

我只想找到那些> zero中最小的一个。

代码语言:javascript
复制
SELECT Market, LiFo, Wgtd_Avg,
(
    CASE
        WHEN Market < LiFo AND Market < Wgtd_Avg AND Market > 0 THEN Market
        WHEN LiFo  < Wgtd_Avg AND LiFo > 0 THEN LiFo
        WHEN Wgtd_Avg > 0 THEN Wgtd_Avg
        ELSE 0
    END
) AS LeastOfThree
FROM VF_CasINV_Cost
EN

回答 2

Stack Overflow用户

发布于 2011-06-30 19:41:54

原始答案:

代码语言:javascript
复制
SELECT min(Value) FROM
(
SELECT Market as Value FROM VF_CasINV_Cost WHERE Market > 0
UNION
SELECT Wgtd_Avg as Value FROM VF_CasINV_Cost WHERE Wgtd_Avg > 0
UNION
SELECT LiFo as Value FROM VF_CasINV_Cost WHERE LiFo > 0
) union_table

评论后编辑:

代码语言:javascript
复制
SELECT Market, Wgtd_Avg, LiFo, min(least) AS leastOfThree FROM
(
SELECT min(market) as market, min(Market) as least FROM VF_CasINV_Cost WHERE Market > 0
UNION
SELECT min(Wgtd_avg) as Wgtd_Avg, min(Wgtd_Avg) as least FROM VF_CasINV_Cost WHERE Wgtd_Avg > 0
UNION
SELECT min(lifo) as LiFo, min(lifo) as least FROM VF_CasINV_Cost WHERE LiFo > 0
) as union_table

我离开了一台装有sql服务器的计算机,所以现在不能测试它,但它应该已经接近工作了……我一回来就对它进行测试和编辑。

票数 2
EN

Stack Overflow用户

发布于 2011-07-01 13:56:49

代码语言:javascript
复制
SELECT
  MIN(
    CASE x.f
      WHEN 1 THEN t.Market
      WHEN 2 THEN t.Wgtd_Avg
      WHEN 3 THEN t.LiFo
    END
  ) AS MinValue
FROM VF_Cas_INV_Cost t
  INNER JOIN (SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) x (f)
    ON CASE x.f
      WHEN 1 THEN t.Market
      WHEN 2 THEN t.Wgtd_Avg
      WHEN 3 THEN t.LiFo
    END > 0
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6534131

复制
相关文章

相似问题

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