首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在一行中查找2、3、4、5非空值(SQL)

在一行中查找2、3、4、5非空值(SQL)
EN

Stack Overflow用户
提问于 2019-12-19 16:12:34
回答 1查看 66关注 0票数 0
代码语言:javascript
复制
ID |val1 | val2 | val3 | val4| val5| val6

1   NULL   NULL     a     b    NULL  NULL

2   NULL   NULL   NULL    b     c    d

对于这两条记录,我想提取第二和第三条非空值。预期结果:

代码语言:javascript
复制
ID | 1st | 2nd | 3rd

1.    a    b    NULL

2.    b   c     d

让我重新表述这个问题,因为这是我正在处理的原始数据格式。我以为找到Nth非空值会更容易,有3家商店。每家商店销售多达6种产品。每个产品可以从1颗星到6颗星。

shop_id \x- prod_id分级

1-a-2

1-b-6

2-a-5

2-b-6

2-c-1

2-d-2

3-a-3

我想按等级对每种产品进行排名。预期的结果将是:

shop_id / prod_id分级级

1-a-2-2

1\x{e76f}b\x{e76f}

2-a-5-2

2-b-6-1

2-c-1-4

2-d-2-2-3

3\x{e76f}a\x{e76f}1

我希望这是清楚的。谢谢你的帮忙!

EN

回答 1

Stack Overflow用户

发布于 2019-12-19 16:44:36

关于我的评论,请扩展如下:

您的模式将更好地作为id | val_id | val,使用您的数据,它将类似于:

代码语言:javascript
复制
+----+--------+------+
| id | val_id | val  |
+----+--------+------+
|  1 |      1 | NULL |
|  1 |      2 | NULL |
|  1 |      3 | a    |
|  1 |      4 | b    |
|  1 |      5 | NULL |
|  1 |      6 | NULL |
|  2 |      1 | NULL |
|  2 |      2 | NULL |
|  2 |      3 | NULL |
|  2 |      4 | b    |
|  2 |      5 | c    |
|  2 |      6 | d    |
+----+--------+------+

这样你就可以回答你的问题如下:

代码语言:javascript
复制
SELECT <TOP 5> * FROM yourtable ORDER BY id, val_id <LIMIT 5>

其中<TOP 5><LIMIT 5>是可互换的,这取决于您所使用的关系数据库管理系统。

要使数据看起来像这个更好的模式,可以使用UNION查询:

代码语言:javascript
复制
SELECT id, 1, val1 FROM yourtable
UNION ALL 
SELECT id, 2, val2 FROM yourtable
UNION ALL
SELECT id, 3, val3 FROM yourtable
UNION ALL
SELECT id, 4, val4 FROM yourtable
UNION ALL
SELECT id, 5, val5 FROM yourtable
UNION ALL
SELECT id, 6, val6 FROM yourtable

您可以将其弹出到一个子查询中,以代替上面的SQL中的yourtable

代码语言:javascript
复制
SELECT <TOP 5> * 
FROM
    (
        SELECT id, 1, val1 FROM yourtable
        UNION ALL 
        SELECT id, 2, val2 FROM yourtable
        UNION ALL
        SELECT id, 3, val3 FROM yourtable
        UNION ALL
        SELECT id, 4, val4 FROM yourtable
        UNION ALL
        SELECT id, 5, val5 FROM yourtable
        UNION ALL
        SELECT id, 6, val6 FROM yourtable
    ) yourtable 
 ORDER BY id, val_id <LIMIT 5>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59413366

复制
相关文章

相似问题

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