我正在创建一个高分服务器,所需的功能之一是能够检索用户当前分数周围的高分。我目前有以下内容:
SELECT * FROM highscores
WHERE score >= ( SELECT score FROM highscores WHERE userID = someID )
ORDER BY score, updated ASC
LIMIT -9, 19
这里唯一的问题是 LIMIT 的偏移参数不能为负数,否则我相信这会起作用。所以总而言之,是否有任何技巧/方法可以为 LIMIT 偏移量提供负偏移量,或者是否有更好的方法来解决这个问题?
您可以在单选查询中做一个真正痛苦的事情,或者只是这样做:
(SELECT * FROM highscores
WHERE score <= ( SELECT score FROM highscores WHERE userID = someID )
ORDER BY score, updated ASC
LIMIT 9)
UNION
(SELECT * FROM highscores
WHERE score = ( SELECT score FROM highscores WHERE userID = someID ))
UNION
(SELECT * FROM highscores
WHERE score >= ( SELECT score FROM highscores WHERE userID = someID )
ORDER BY score, updated ASC
LIMIT 9)
我放入了一块来获取指定用户的分数,因此它位于列表的中间。如果需要的话可选。另外,不要使用 SELECT *,使用特定字段。清晰度总是更好,但从性能角度来说, * 很糟糕。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)