启源 2017-03-31 04:14 采纳率: 0%
浏览 1107

求助一条关于UNION查询的SQL怎么优化

有三个字段出自同一张表

 SELECT  s.PAY_TYPE,bs.PAY_ORDER AS JY_RC_ORDER,
        **bs.RECEIVE_AMOUNT_FIRST** AS RECEIVE_AMOUNT,
       ** bs.RECEIVE_TIME_FIRST **AS RECEIVE_TIME,
       ** bs.RECEIVE_TYPE_FIRST** AS RECEIVE_TYPE,S.ORDER_NUMBER,S.PAY_AMOUNT,S.PAYMENT_DATE,S.PAY_WAY,s.YXP_AMT 
FROM B2B_BIGSTAGE_SUB s
LEFT JOIN YX_BUYERS bs 
ON s.ORDER_NUMBER=bs.PAY_ORDER
WHERE bs.PAY_ORDER IS NULL AND s.ORDER_NUMBER IS NOT NULL AND s.ORDER_NUMBER LIKE 'JY%' OR s.ORDER_NUMBER LIKE 'RC%'
UNION
SELECT s.PAY_TYPE,bs.PAY_ORDER AS JY_RC_ORDER,
       ** bs.RECEIVE_AMOUNT_SED** as RECEIVE_AMOUNT,
      **  bs.RECEIVE_TIME_SED **AS RECEIVE_TIME,
       ** bs.RECEIVE_TYPE_SED **AS RECEIVE_TYPE,S.ORDER_NUMBER,S.PAY_AMOUNT,S.PAYMENT_DATE,S.PAY_WAY,s.YXP_AMT
FROM B2B_BIGSTAGE_SUB s  
LEFT JOIN YX_BUYERS bs
ON s.ORDER_NUMBER=bs.PAY_ORDER
WHERE bs.PAY_ORDER IS NULL AND s.ORDER_NUMBER IS NOT NULL AND s.ORDER_NUMBER LIKE 'JY%' OR s.ORDER_NUMBER LIKE 'RC%'
  • 写回答

2条回答

  • Tiger_Zhao 2017-03-31 09:14
    关注

    从字段意义上猜 RECEIVE_AMOUNT_FIRSTRECEIVE_AMOUNT_SED 是不能去重复的,你至少应该是用 UNION ALL 吧,不用去重复查询会快很多。

    如果要两个数量合并,相加即可

     SELECT s.PAY_TYPE,bs.PAY_ORDER AS JY_RC_ORDER,
            (ISNULL(bs.RECEIVE_AMOUNT_FIRST,0) + ISNULL(bs.RECEIVE_AMOUNT_SED,0)) AS RECEIVE_AMOUNT,
            ISNULL(bs.RECEIVE_TIME_FIRST, bs.RECEIVE_TIME_SED) AS RECEIVE_TIME,
            ISNULL(bs.RECEIVE_TYPE_FIRST, bs.RECEIVE_TYPE_SED) AS RECEIVE_TYPE,
            S.ORDER_NUMBER,S.PAY_AMOUNT,S.PAYMENT_DATE,S.PAY_WAY,s.YXP_AMT 
    FROM B2B_BIGSTAGE_SUB s
    LEFT JOIN YX_BUYERS bs 
    ON s.ORDER_NUMBER=bs.PAY_ORDER
    WHERE bs.PAY_ORDER IS NULL AND s.ORDER_NUMBER IS NOT NULL AND s.ORDER_NUMBER LIKE 'JY%' OR s.ORDER_NUMBER LIKE 'RC%'
    
    
    评论

报告相同问题?

悬赏问题

  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮