我是 MySQL 的初学者并且被卡住了。 我想我必须做某种“高级”子查询来解决我的问题,但我不知道如何做。有人可以帮助我吗?
第一个查询 连接三个表,“annons”、“kontering_annons”和“member”。 结果是唯一的“annons.id”条目。 (在我的例子中有 3 个结果)。 问题是我需要在表“kontering_annons”中为每个唯一的“annons.id”找到last 条目。这个查询没有。
SELECT annons.id, annons.id_user, member.saldo, member.id,
kontering_annons.id_annons, kontering_annons.dat_bet_till,
kontering_annons.id_kontering_a, kontering_annons.dat_ut_member
FROM annons
LEFT JOIN kontering_annons
ON kontering_annons.id_annons = annons.id
LEFT JOIN member
ON member.id = annons.id_user
WHERE (annons.status='3' OR annons.status='4')
AND annons.typ='d'
AND annons.startar < NOW() - 48*60*60
AND kontering_annons.dat_bet_till < CURRENT_DATE()
AND member.saldo >= $day_price
GROUP BY annons.id
第二个 查询显示表“kontering_annons 中每个“id_annons”的last 条目。(在我的例子中有 18 个结果)。 我想我需要将此查询与上面的查询结合起来,以便能够仅找到具有 latest entry-id 的三个唯一条目。但是如何呢?
SELECT a.*
FROM kontering_annons a
INNER JOIN (SELECT id_annons, dat_bet_till, max(id_kontering_a)
AS maxid
FROM kontering_annons
GROUP BY id_annons)
AS b
ON a.id_kontering_a = b.maxid
最佳答案
试试这个:
SELECT
a.id,
a.id_user,
m.saldo,
m.id,
k.id_annons,
k.dat_bet_till,
k.id_kontering_a,
k.dat_ut_member
FROM annons a
INNER JOIN
(
SELECT
id_annons,
dat_bet_till,
max(id_kontering_a) AS maxid
FROM kontering_annons
GROUP BY id_annons
) km ON a.id = km.id_annons
LEFT JOIN kontering_annons k ON k.id_annons = km.id_annons
AND k.id_kontering_a = km.maxid
LEFT JOIN member m ON m.id = a.id_user
WHERE (a.status='3' OR a.status='4')
AND a.typ='d'
AND a.startar < NOW() - 48*60*60
AND k.dat_bet_till < CURRENT_DATE()
AND m.saldo >= $day_price
我在这里所做的是 INNER JOIN
表 annons
具有:
SELECT
id_annons,
dat_bet_till,
max(id_kontering_a) AS maxid
FROM kontering_annons
GROUP BY id_annons
ON a.id = km.id_annons
然后用 kontering_annons
JOIN
它,只选择最后一个表的所有数据通过 kid_kontering_a = km.maxid
加入 id_kontering_a
。
请注意:我使用了 INNER JOIN
然后两个 LEFT JOIN
来保持它 LEFT JOIN
否则如果你执行 LEFT JOIN
然后 INNER JOIN
以获得最大 ID,这将是一个 INNER JOIN
。
关于php - Mysql,结合 JOIN 和 SORT BY 的多个查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13669781/