4

我目前正在开发一个拍卖系统,功能齐全。我现在需要在用户的个人资料中添加一个计数,以显示用户当前正在竞标的项目数量。

该系统由两个关键表组成(当然,系统中有额外的表功能,但这些是与此问题相关的唯一表):

item_sales

+-----+------------------+------------+-------------+---------+
| id  |  selling_format  |  duration  |  list_date  |  buyer  |
+-----+------------------+------------+-------------+---------+

item_sales_bids

+-----+-------------+-----------+---------------+-----------+--------+
| id  |  sale_item  |  user_id  |  current_bid  |  max_bid  |  date  |
+-----+-------------+-----------+---------------+-----------+--------+

item_sales_bids. date是投标时间的 Unix 时间戳。

我可以通过以下查询轻松计算给定用户的所有出价:

   SELECT COUNT(DISTINCT(`item_sales_bids`.`user_id`)) AS `total`,
          SUM((`sale`.`list_date` + (`sale`.`duration` * 86400)) - UNIX_TIMESTAMP()) AS `endTime`
     FROM `item_sales_bids`
INNER JOIN `item_sales` `sale` ON `item_sales_bids`.`sale_item` = `sale`.`id`
     WHERE `user_id` = 1
  GROUP BY `sale_item`
    HAVING `endTime` > 0

我想做的是运行与上述类似的查询,但只包括指定用户是当前最高出价者的记录(即,给定项目的出价集的最大 ID 条目对user_id我们的用户有一个值 =)。

不幸的是,我不知道如何实现这一目标。

我已经设置了一个 SQLFiddle 来协助 > http://sqlfiddle.com/#!2/b98e4/3

4

2 回答 2

2

执行 subs 查询以获取所有项目的最新出价,然后将其加入 item_sales_bids 以仅处理最新项目。

像这样的东西: -

SELECT COUNT(DISTINCT(item_sales_bids.user_id)) AS total,
SUM((sale.list_date + (sale.duration * 86400)) - UNIX_TIMESTAMP()) AS endTime
FROM item_sales_bids
INNER JOIN item_sales sale ON item_sales_bids.sale_item = sale.id
INNER JOIN
(
    SELECT sale_item, MAX(id) AS LatestBid
    FROM item_sales_bids
    GROUP BY sale_item
) Sub1
ON item_sales_bids.sale_item = Sub1.sale_item AND item_sales_bids.id = Sub1.LatestBid
WHERE user_id = 1
GROUP BY item_sales_bids.sale_item
HAVING endTime > 0
于 2013-07-31T11:53:29.983 回答
0

这应该可以解决问题。在用户 1 和 2 之间切换将显示所需的行为。在样本数据中,用户 1 没有返回任何数据(他们不是最高出价者),用户 2 返回一行,当前最高出价为 50。

    SELECT COUNT(DISTINCT(`bids`.`user_id`)) AS `total`,
  `highbids`.`sale_item`,
  `highbids`.`maxBid`,
  SUM((`sale`.`list_date` + (`sale`.`duration` * 86400)) - UNIX_TIMESTAMP()) AS `endTime`
FROM `item_sales_bids` `bids`
INNER JOIN `item_sales` `sale` ON `bids`.`sale_item` = `sale`.`id`
INNER JOIN (SELECT MAX(`current_bid`) AS `maxBid`, `sale_item`, `user_id` 
  FROM `item_sales_bids` 
  GROUP BY `sale_item`, `user_id`
  ORDER BY `current_bid` DESC LIMIT 1,1) 
AS `highbids` ON `bids`.`user_id` = `highbids`.`user_id`
WHERE `bids`.`user_id` = 2
GROUP BY `bids`.`sale_item`
HAVING `endTime` > 0
于 2013-07-31T12:11:19.060 回答