我目前正在开发一个拍卖系统,功能齐全。我现在需要在用户的个人资料中添加一个计数,以显示用户当前正在竞标的项目数量。
该系统由两个关键表组成(当然,系统中有额外的表功能,但这些是与此问题相关的唯一表):
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