gpt4 book ai didi

php - MySQL获取查询中的行位置

转载 作者:行者123 更新时间:2023-11-29 01:58:09 25 4
gpt4 key购买 nike

这是我思考了数小时但仍无法得到答案的问题。我想获得行位置。

所以,我有这个名为“订单”的 mysql 表

+-----------------------------+
+ id | bid +
+-----------------------------+
+ 1 | 4.00 +
+ 2 | 6.00 +
+ 3 | 5.00 +
+ 4 | 4.00 +
+-----------------------------+

而且我已经设法通过这个函数获得了行位置

SELECT p.*, (SELECT count(*) FROM orders WHERE bid > p.bid) AS position FROM orders p

输出是

+-----------------------------+
+ id | bid | position +
+-----------------------------+
+ 1 | 4.00 | 3 +
+ 2 | 6.00 | 1 +
+ 3 | 5.00 | 2 +
+ 4 | 4.00 | 3 +
+-----------------------------+

请注意,如果值相同,则它们的位置相同。

所以我现在需要的是一个查询,我可以在其中选择一个新出价(该出价在表格中不存在)并告诉我该出价将处于哪个位置。它应该是这样的:如果我的新出价是 7.00,它会在哪个位置? (答案:1个位置),又如:如果我的新出价是4.00,会在哪个位置? (答案:3 个位置)

我正在寻找用 SQL 完成的任务。如果不可能,那么我会喜欢一个 php 答案。

我希望你们能帮我解决这个问题,过去几个小时我一直在焦头烂额,但没能完成这件事。

非常感谢您。

最佳答案

首先,我认为您应该在子查询中添加一个 DISTINCT 关键字。因为如果我们将 bid=3 添加到表中,您的查询将获得 position = 5。所以 4 将被遗漏。

SELECT p.*, 
(SELECT count(DISTINCT bid)+1
FROM orders WHERE bid > p.bid) AS position
FROM orders p

SQLFiddle demo

现在我们需要知道新的 bid 的位置。只需使用您的子查询:

SELECT count(DISTINCT bid)+1 FROM orders WHERE bid > 4

关于php - MySQL获取查询中的行位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22525040/

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