仅 Sql Pivot 前 N 行

发布于 2024-09-24 09:17:17 字数 275 浏览 2 评论 0原文

我有以下结构

Col1 Col2 Col3  
---------------
F     P    R1
F     P    R2
F     P    R3
F     P    R4

Col3 值可以是任何东西 现在我只想要以下格式的前 3 个

Col1 Col2 Res1 Res2 Res3  
------------------------------
F     P    R1   R2   R3

I have Following structure

Col1 Col2 Col3  
---------------
F     P    R1
F     P    R2
F     P    R3
F     P    R4

Col3 values can be any thing
Now I want in following format only top 3

Col1 Col2 Res1 Res2 Res3  
------------------------------
F     P    R1   R2   R3

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

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

发布评论

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

评论(3

卖梦商人 2024-10-01 09:17:17

如果使用 SQL Server 2005+、Oracle 8i+、PostgreSQL 8.4+——您可以使用分析函数:

  SELECT x.col1, x.col2,
         MAX(CASE WHEN x.rk = 1 THEN x.col3 END) AS Res1,
         MAX(CASE WHEN x.rk = 2 THEN x.col3 END) AS Res2,
         MAX(CASE WHEN x.rk = 3 THEN x.col3 END) AS Res3
    FROM (SELECT yt.col1,
                 yt.col2,
                 yt.col3,
                 ROW_NUMBER() OVER(PARTITION BY yt.col1, yt.col2
                                       ORDER BY yt.col3) AS rk
            FROM YOUR_TABLE yt) x
GROUP BY x.col1, x.col2

If using SQL Server 2005+, Oracle 8i+, PostgreSQL 8.4+--you can use analytic functions:

  SELECT x.col1, x.col2,
         MAX(CASE WHEN x.rk = 1 THEN x.col3 END) AS Res1,
         MAX(CASE WHEN x.rk = 2 THEN x.col3 END) AS Res2,
         MAX(CASE WHEN x.rk = 3 THEN x.col3 END) AS Res3
    FROM (SELECT yt.col1,
                 yt.col2,
                 yt.col3,
                 ROW_NUMBER() OVER(PARTITION BY yt.col1, yt.col2
                                       ORDER BY yt.col3) AS rk
            FROM YOUR_TABLE yt) x
GROUP BY x.col1, x.col2
白馒头 2024-10-01 09:17:17

您可以执行以下操作:

SELECT Col1, Col2,
    MAX(CASE Col3 WHEN 'R1' THEN 'R1' END) as Res1,
    MAX(CASE Col3 WHEN 'R2' THEN 'R2' END) as Res2,
    MAX(CASE Col3 WHEN 'R3' THEN 'R3' END) as Res3
FROM MyTable
GROUP BY Col1, Col2

You can do the following:

SELECT Col1, Col2,
    MAX(CASE Col3 WHEN 'R1' THEN 'R1' END) as Res1,
    MAX(CASE Col3 WHEN 'R2' THEN 'R2' END) as Res2,
    MAX(CASE Col3 WHEN 'R3' THEN 'R3' END) as Res3
FROM MyTable
GROUP BY Col1, Col2
知足的幸福 2024-10-01 09:17:17

您寻求的是一个动态交叉表查询,它将根据 Col3 中的值构建列。 SQL 语言不是为动态列生成而设计的,因此如果没有一些模糊的动态 SQL,这种类型的查询就无法在 T-SQL 中完成。相反,我建议您在中间层组件中构建查询或使用报告工具。

What you seek is a dynamic crosstab query that will build columns out of the values in Col3. The SQL language was not designed for dynamic column generation and thus this type of query cannot be done in T-SQL without some fugly dynamic SQL. Instead, I would recommend you build your query in a middle-tier component or use a reporting tool.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文