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

标签 php mysql sql

我是 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/

相关文章:

php - 如何在codeigniter中定义全局变量?

php - 将 mysql 存储的点放在谷歌地图上

php - 如何排除选择和所有相关的(MySQL + PHP)

java - 结果集未打开。验证自动提交是否关闭。 Apache 德布里

php - 选择与查询返回的结果相反的结果

mysql - 选择显示第一个唯一值的行

php - 如何使用 SELECT SUM() FROM Table GROUP BY 进行删除

php - 每个公共(public)属性都必须有访问器方法吗?

sql - 使用 MAX 和 GROUP BY 选择所有对应的字段

mysql - 扩展从数据库中获取数据的规模