首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MySQL -选择有限制的行

MySQL -选择有限制的行
EN

Stack Overflow用户
提问于 2018-06-14 05:15:03
回答 1查看 40关注 0票数 0

如何根据条件(使用IN或任何其他条件)选择一定数量的行,如果条件返回的行数小于LIMIT x,则如何从剩余行中进行选择,直到满足LIMIT x

因此,如果我有下表:

代码语言:javascript
复制
id   comment   ord
1    ...       null
2    ...       1
3    ...       2
4    ...       null

那么结果集应该是,使用LIMIT 3

代码语言:javascript
复制
id   comment   ord
2    ...       1
3    ...       2
1    ...       null

如果ord列不为null,那么我希望选择相应的行,如果不是,我希望从具有ord NULL的其余行中选择一个或多个,直到达到LIMIT 3条件。

另一个例子是,如果我有下一个表数据:

代码语言:javascript
复制
id   comment   ord
1    ...       3
2    ...       1
3    ...       2
4    ...       null

则结果集应为

代码语言:javascript
复制
id   comment   ord
2    ...       1
3    ...       2
1    ...       3

我已经尝试过下面的mysql代码:

代码语言:javascript
复制
SELECT t.* FROM table t 
WHERE 
    t.ord IN (SELECT t1.ord FROM table t1 WHERE t1.ord IS NOT NULL ORDER BY t1.ord ASC) 
    OR 
    t.id IN (SELECT t2.id FROM table t2 WHERE t2.ord IS NULL ORDER BY t2.id ASC)
LIMIT 3;

但是我总是得到包含ord NULL的行,即使我有一些ord列不为空。

有什么需要帮忙的吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-14 06:09:14

ORDER BY中检查ord是否为null

代码语言:javascript
复制
SELECT *
FROM table
ORDER BY ord IS NULL, ord, id
LIMIT 3

对于非null ordord IS NULL将为0,对于null ord,将为1,因此这将首先放置所有非null行。其中,它将按ord排序,其余部分将按id排序。

然后LIMIT 3将选择所有这些中的前3个。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50846387

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档