发布
社区首页 >问答首页 >两个具有不同行的表连接网格

两个具有不同行的表连接网格
EN

Stack Overflow用户
提问于 2014-09-23 14:27:18
回答 1查看 161关注 0票数 2

我想建一张这样的桌子:

简介

两个表中的所有列。

按不同的日行排列。

每日所有应付款项之和NAEDO

每天汇总所有成功/不成功的付款。paysoft

当天付款总额

当日未缴款项共计

在这个网格中表示了两个表。

您有应付[NAEDO]的付款,也有已支付/或失败的[paysoft]付款

每天有多个事务,网格按日分组,当天的事务汇总在该行中。

带有测试数据的小提琴

我试了一下,但我很难加入这两张桌子。

代码语言:javascript
代码运行次数:0
复制
SELECT 
    n.day,
    n.ACCOUNTS,
    ammount
FROM 
(
    SELECT  DISTINCT start_date, extract(day from start_date) as day, count(*)as ACCOUNTS, sum(amount)as ammount
    FROM NAEDO
    WHERE start_date >= '2014-08-13' AND start_date <= '2014-09-12'
    GROUP BY start_date
    ORDER BY start_date
) n
LEFT JOIN
(
    ????
) ps ON ps. = ps.custno
GROUP BY start_date, n.day, n.ACCOUNTS, ammount
ORDER BY start_date

因此,此查询(没有第二个空白查询)将创建行,并输入当天到期的金额和当天应付的帐户金额。

但是,试图加入这些表会删除我的DISTINCT选择。

请帮助或指导我达到这个目的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-23 15:45:46

如果我正确地读取了所需的表,则不需要不同的表,而且联接条件是错误的。看起来你试图根据客户号码加入,但你对此并不感兴趣。相反,您需要参加一个约会(n.start_date = ps.pay_date)。我更新了您的代码,以显示我认为您希望您的连接工作。

代码语言:javascript
代码运行次数:0
复制
SELECT 
  n.day,
  n.ACCOUNTS,
  n.ammount,
  ps.amt_paid
FROM 
(
  SELECT  start_date, extract(day from start_date) as day, count(*)as ACCOUNTS, sum(amount)as ammount
  FROM NAEDO
  WHERE start_date >= '2014-07-13' AND start_date <= '2014-08-12'
  GROUP BY start_date
  ORDER BY start_date
) n
LEFT JOIN
(
  Select pay_date, sum(amount) as amt_paid
  From paysoft
  Group By pay_date
  Order By pay_date
) ps On n.start_date = ps.pay_date
Order By n.start_date

这不包括确定成功率的逻辑,也不排除amt_paid中的失败付款,但它应该会让您开始工作。以这种方式构造查询也会导致计算帐户数量的问题。如上文所述,它只计算在某一天应付款的帐户数目。它可以很容易地更改为还包括在特定的一天已经付款的帐户,但你可能会有一些帐户两次清点。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25997686

复制
相关文章

相似问题

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