gpt4 book ai didi

php - Mysql,结合 JOIN 和 SORT BY 的多个查询

转载 作者:可可西里 更新时间:2023-11-01 07:45:22 24 4
gpt4 key购买 nike

我是 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 JOINannons 具有:

    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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com