我有一张“Empresas” table
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 的第二个周期,并比较它们。
谢谢
最佳答案
这是我的查询:
SELECT
empresas.name,
pagos.periodo,
pagos.monto
FROM
pagos INNER JOIN (
SELECT
lst.id id1,
prc.id id2
FROM (
SELECT
p1.id_empresa,
MAX(p1.periodo) last_p,
MAX(p2.periodo) prec_p
FROM
pagos p1 INNER JOIN pagos p2
ON p1.id_empresa = p2.id_empresa
AND p2.periodo < p1.periodo
GROUP BY
id_empresa) latest
INNER JOIN
pagos lst ON lst.id_empresa = latest.id_empresa AND lst.periodo=latest.last_p
INNER JOIN
pagos prc ON prc.id_empresa = latest.id_empresa AND prc.periodo=latest.prec_p
WHERE
lst.monto > prc.monto * 1.1) ids
ON pagos.id IN (ids.id1, ids.id2)
INNER JOIN
empresas
ON pagos.id_empresa = empresas.id
WHERE
delegacion_id=3
我认为如果你想在同一行上有值,可以简化它,例如
name | ultimo_periodo | ultimo_monto | anterior_periodo | anterior_monto
请参阅 fiddle here .
我仍然想知道是否可以简化一点,但我不确定是否可以。这是另一个解决方案:
SELECT
empresas.name,
pagos.periodo,
pagos.monto
FROM
pagos INNER JOIN empresas
ON pagos.id_empresa = empresas.id
INNER JOIN (
SELECT
id_empresa,
MAX(CASE WHEN row=1 THEN monto END) lst_monto,
MAX(CASE WHEN row=2 THEN monto END) prc_monto,
MAX(id) id1, MIN(id) id2
FROM (
SELECT
p1.*, COUNT(*) row
FROM
pagos p1 INNER JOIN pagos p2
ON p1.id_empresa = p2.id_empresa
AND p1.periodo <= p2.periodo
INNER JOIN empresas
ON p1.id_empresa = empresas.id
WHERE
empresas.delegacion_id = 3
GROUP BY
p1.id, p1.id_empresa, p1.monto, p1.periodo
HAVING
COUNT(*)<=2
ORDER BY
p1.id_empresa, p1.periodo desc
) s
GROUP BY
id_empresa
HAVING
lst_monto>prc_monto*1.1
) l ON pagos.id IN (l.id1, l.id2)
请参阅 fiddle here .
关于mysql - 比较组第一行和第二行之间的差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15935943/