我有一个“Empresas”表
dbo.empresas
id | name | delegacion_id
-------------------------
1 | A | 3
2 | B | 3
3 | C | 3
4 | D | 4
一个“pagos”表
dbo.pagos
id | id_empresa | monto | periodo
----------------------------------
1 | 1 | 120 | 2012-11-01
2 | 1 | 125 | 2012-12-01
3 | 2 | 150 | 2012-11-01
4 | 1 | 200 | 2013-01-01
5 | 2 | 151 | 2012-12-01
我有一个值 X,它是一个百分比。
我需要向“empresas”展示,比较他们最后两个“pagos”(按 periodo 排序)的“montos”,从特定的 id_delegacion 至少改变了 +X% 或 -X%
例如,如果我们使用这些示例值运行此查询,考虑到
X = 10 id_delegacion = 3
预期的输出将是:
name | periodo | monto
---------------------------
A | 2012-12-01 | 125
A | 2013-01-01 | 200
empresa A 来自 delegacion_id = 3,最后两个 pagos 之间的比较,按 periodo desc (200 => 125) 排序大于 10%。
B 未显示,因为比较小于 10%。
C 未显示,因为“pagos”表中没有行
D 来自另一个代表团。
我怎样才能得到这个想要的输出?作为记录,使用 MySQL 5.5.8。
我做了什么
我懂了
select P.id_empresa, max(periodo) as periodo from
pagos P
where id_empresa in(
select e.id
from empresa E
where E.id_delegacion = 3
)
group by p.id_empresa, p.periodo
having count(*) > 1
有了这些,我得到了具有多个“pago”行的“empresas”,并且得到了 id_delegation = 3。还获得了第一个时期(最大值),但我不知道如何为每个 empresa 获得第二个时期,并且比较它们。
谢谢