在 mysql 中查找下一行/上一行时出现问题

发布于 2024-09-06 00:23:26 字数 262 浏览 1 评论 0原文

SELECT id ,MAX(status) AS status FROM Mail WHERE 
     status < (SELECT status FROM Mail WHERE id = 1000) 
     GROUP BY status ORDER BY status DESC LIMIT 1;

我正在使用此查询来查找当前行 1000 的前一行。如果我使用不唯一的状态列,我将得到 NULL 值。如果我使用唯一列,它会给出正确的值。

SELECT id ,MAX(status) AS status FROM Mail WHERE 
     status < (SELECT status FROM Mail WHERE id = 1000) 
     GROUP BY status ORDER BY status DESC LIMIT 1;

I am using this query to find the previous row of the current row 1000.Here i am getting NULL values if i use the status column which is not unique.where as it gives proper values if i use unique columns.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

独﹏钓一江月 2024-09-13 00:23:26

试试这个:

SELECT m1.id, MAX(m1.status) AS 'status' FROM Mail m1, Mail m2
WHERE m1.status < m2.status AND m2.id = 1000
GROUP BY m1.status ORDER BY m1.status DESC LIMIT 1;

Try this:

SELECT m1.id, MAX(m1.status) AS 'status' FROM Mail m1, Mail m2
WHERE m1.status < m2.status AND m2.id = 1000
GROUP BY m1.status ORDER BY m1.status DESC LIMIT 1;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文