【问题标题】:Select query to pull same record twice选择查询以两次提取相同的记录
【发布时间】:2016-01-28 02:43:50
【问题描述】:

我想使用选择查询两次提取同一记录,但第二次为其中一个字段使用不同的值。

所以我有一个选择查询,它当前提取数据并显示以下示例:

ProductCode   Description   Price   Currency
123           Product1      200     CAD

现在我想使用选择查询第二次提取相同的记录,但我想使用美元而不是 CAD,所以它应该显示:

ProductCode   Description   Price   Currency
123           Product1      200     CAD
123           Product1      200     USD

“CAD”现在在选择查询中是硬编码的,我希望这是有道理的,例如。现在的选择查询是:

select productcode,description,price, 'CAD' as Currency from product_table

【问题讨论】:

    标签: sql select duplicates default record


    【解决方案1】:

    联合呢?

    SELECT ProductCode, Description, price_in_cad as Price, 'CAD' as Currency FROM product_table
    UNION ALL
    SELECT ProductCode, Description, price_in_usd as Price, 'USD' as Currency FROM product_table;
    

    或者,如果您想对其进行排序或过滤,则可以从中进行子查询:

    SELECT result.* FROM (
      SELECT ProductCode, Description, price_in_cad as Price, 'CAD' as Currency FROM product_table
    UNION ALL
      SELECT ProductCode, Description, price_in_usd as Price, 'USD' as Currency FROM product_table
    ) result ORDER BY Price;
    

    【讨论】:

    • 天哪,其实就是这么简单,谢谢,UNION ALL 工作了!
    猜你喜欢
    • 1970-01-01
    • 2021-03-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-02-17
    相关资源
    最近更新 更多