首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化联合查询中的连接

优化联合查询中的连接
EN

Stack Overflow用户
提问于 2012-03-14 16:17:21
回答 2查看 185关注 0票数 0

如何使用联合和连接优化查询?在这里可以将一些连接移动到联盟之外吗?

代码语言:javascript
复制
(
    SELECT accounting.id, accounting.time, accounting.subaccount_id AS module_id, accounting.balance_invoice_id AS balance_id, accounting.currency_amount*-1 AS currency_amount, accounting.amount*-1 AS amount, enclosure.enc_id_, enclosure.txt, currency.name AS currency_name, IF(balance_invoice.amount, accounting.currency_amount*-1+SUM(balance_invoice.amount), accounting.currency_amount*-1) AS balance
    FROM accounting
    INNER JOIN enclosure ON enclosure.id=accounting.enc_id
    LEFT JOIN currency ON currency.id=accounting.currency_id
    LEFT JOIN balance_invoice ON balance_invoice.accounting_id=accounting.id
    WHERE accounting.att_booked=1
    GROUP BY accounting.id
)
UNION (
    SELECT accounting.id, accounting.time, accounting.subaccountoff_id AS module_id, accounting.balanceoff_invoice_id AS balance_id, accounting.currency_amount, accounting.amount, enclosure.enc_id_, enclosure.txt, currency.name AS currency_name, IF(balance_invoice.amountoff, accounting.currency_amount+SUM(balance_invoice.amountoff), accounting.currency_amount) AS balance
    FROM accounting
    INNER JOIN enclosure ON enclosure.id=accounting.enc_id
    LEFT JOIN currency ON currency.id=accounting.currency_id
    LEFT JOIN balance_invoice ON balance_invoice.accounting_id=accounting.id
    WHERE accounting.att_booked=1 && accounting.type IN (0,1,2)
    GROUP BY accounting.id
) ORDER BY time DESC
EN

回答 2

Stack Overflow用户

发布于 2012-03-14 16:37:45

像这样的东西-

代码语言:javascript
复制
SELECT
  a.id,
  a.time,
  IF(a.acc_type = 1, a.subaccount_id, subaccountoff_id) AS module_id,
  IF(a.acc_type = 1, a.balance_invoice_id, balanceoff_invoice_id) AS balance_id,
  IF(a.acc_type = 1, a.currency_amount * -1, currency_amount) AS currency_amount,
  IF(a.acc_type = 1, a.amount * -1, a.amount) AS amount,
  e.enc_id_,
  e.txt,
  c.name AS currency_name,
  IF(a.acc_type = 1,
    IF(bi.amount, a.currency_amount * - 1 + SUM(bi.amount), a.currency_amount * -1),
    IF(bi.amountoff, a.currency_amount + SUM(bi.amountoff), a.currency_amount)
  ) AS balance
FROM (
  SELECT 1 acc_type, a1.* FROM accounting a1 WHERE a1.att_booked = 1
    UNION
  SELECT 2 acc_type, a2.* FROM accounting a2 WHERE a2.att_booked=1 AND a2.type IN (0,1,2)
  ) a
INNER JOIN enclosure e
  ON e.id = a.enc_id
LEFT JOIN currency c
  ON c.id = a.currency_id
LEFT JOIN balance_invoice bi
  ON bi.accounting_id = a.id
GROUP BY
  a.id
ORDER BY
  time DESC;
票数 1
EN

Stack Overflow用户

发布于 2012-03-14 16:40:13

这在没有工会的情况下也应该是可行的。相反,我使用了几个CASE语句。未经测试:

代码语言:javascript
复制
SELECT a.id, a.time
      ,CASE WHEN a.type IN (0,1,2) THEN a.subaccountoff_id      ELSE a.subaccount_id      END AS module_id
      ,CASE WHEN a.type IN (0,1,2) THEN a.balanceoff_invoice_id ELSE a.balance_invoice_id END AS balance_id
      ,CASE WHEN a.type IN (0,1,2) THEN a.currency_amount       ELSE a.currency_amount*-1 END AS currency_amount
      ,CASE WHEN a.type IN (0,1,2) THEN a.currency_amount       ELSE a.amount*-1          END AS amount
      ,e.enc_id_, e.txt, c.name AS currency_name
      ,CASE WHEN a.type IN (0,1,2)
            THEN IF (b.amountoff, a.currency_amount + SUM(b.amountoff), a.currency_amount) 
            ELSE IF (b.amount,    a.currency_amount*-1 + SUM(b.amount), a.currency_amount*-1) END AS balance
FROM   accounting a
JOIN   enclosure e ON e.id = a.enc_id
LEFT   JOIN currency c ON c.id = a.currency_id
LEFT   JOIN balance_invoice b ON b.accounting_id = a.id
WHERE  a.att_booked = 1
GROUP  BY a.id
ORDER  BY a.time DESC
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9698087

复制
相关文章

相似问题

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