gpt4 book ai didi

MySQL连接两个表以查找除具有最大值的行之外的所有行

转载 作者:行者123 更新时间:2023-11-29 00:36:25 24 4
gpt4 key购买 nike

我正在尝试编写一个查询,该查询将查找组中除具有最大值的行之外的所有行。到目前为止,我有一个查询可以找到具有最大值的行,但现在我需要找到所有其余的行。这是一个包含两个数据库和示例数据的 SQLFiddle。我还有查找最大行数的查询。 http://sqlfiddle.com/#!2/514d2/33

对于那些不想使用 SQLFiddle 的人...表名:listings表名:出价

SELECT listings.end_date, listings.user_id, listings.title, 
listings.auc_fp, listings.id, listings.auc_image1
FROM listings
JOIN bids b1
ON b1.listing_id=listings.id
LEFT JOIN bids b2
ON b2.listing_id=listings.id AND b1.bid < b2.bid
WHERE b1.user_id = 1
AND b2.bid IS NULL
AND listings.end_date > NOW()
ORDER BY listings.list_ts DESC

以上是查找最大行数的查询。我正在尝试将列表表与 listings.id=bids.listing_id 上的出价表连接起来。然后我需要找到用户($user 或用户“1”)对该列表出价的所有行。然后我需要排除用户具有最高出价的列表(这是上面的查询所做的)。

我最初认为我可以使用上面的查询作为子查询来排除用户是最高出价者的列表。但我不确定这是否是最好的方法,而且我不太擅长子查询。

最佳答案

请注意,根据以下评论多次修改答案。

SELECT
lst.end_date,
lst.title,
lst.auc_fp,
lst.id as listing_id,
lst.auc_image1,
b.user_id as bid_user_id,
b.bid as bid_amount,
maxbids.maxbid as maxbid_for_listing
FROM listings lst
INNER JOIN
(
SELECT listing_id, MAX(bid) maxbid
FROM bids b
GROUP BY listing_id
) maxbids ON lst.id = maxbids.listing_id
INNER JOIN bids maxusers ON maxusers.bid = maxbids.maxbid AND maxusers.listing_id = maxbids.listing_id
INNER JOIN bids b ON
maxbids.listing_id = b.listing_Id AND
b.bid < maxbids.maxbid AND
b.user_id <> maxusers.user_id
WHERE lst.end_date > NOW()
ORDER BY lst.list_ts DESC

关于MySQL连接两个表以查找除具有最大值的行之外的所有行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14086041/

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