我想建一张这样的桌子:
简介
两个表中的所有列。
按不同的日行排列。
每日所有应付款项之和NAEDO
表
每天汇总所有成功/不成功的付款。paysoft
表
当天付款总额
当日未缴款项共计
在这个网格中表示了两个表。
您有应付[NAEDO]
的付款,也有已支付/或失败的[paysoft]
付款
每天有多个事务,网格按日分组,当天的事务汇总在该行中。
带有测试数据的小提琴
我试了一下,但我很难加入这两张桌子。
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
选择。
请帮助或指导我达到这个目的。
发布于 2014-09-23 15:45:46
如果我正确地读取了所需的表,则不需要不同的表,而且联接条件是错误的。看起来你试图根据客户号码加入,但你对此并不感兴趣。相反,您需要参加一个约会(n.start_date = ps.pay_date
)。我更新了您的代码,以显示我认为您希望您的连接工作。
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
中的失败付款,但它应该会让您开始工作。以这种方式构造查询也会导致计算帐户数量的问题。如上文所述,它只计算在某一天应付款的帐户数目。它可以很容易地更改为还包括在特定的一天已经付款的帐户,但你可能会有一些帐户两次清点。
https://stackoverflow.com/questions/25997686
复制相似问题