V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
h3xz
V2EX  ›  数据库

如何对 SQLite 数据库中的表进行分组之后的结果再进行分组?

  •  
  •   h3xz · 123 天前 · 1110 次点击
    这是一个创建于 123 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在 SQLIte 数据库中有一张表,表中的内容如下所示:

    group1 index
    1 1
    1 1
    1 2
    1 2
    1 4
    1 4
    2 1
    2 1
    2 3
    2 3
    2 4
    2 4

    现在希望能够以group进行分组,并在该组内以每两行数据为一组进行升序编号,编号的结果如下所示:

    group index
    1 1
    1 1
    1 2
    1 2
    1 3
    1 3
    2 1
    2 1
    2 2
    2 2
    2 3
    2 3

    请问能使用 SQL 语句实现吗?如果能的话,麻烦大佬指点一二。非常感谢🙏🙏

    4 条回复    2024-07-25 18:45:56 +08:00
    codehz
        1
    codehz  
       123 天前 via iPhone
    这也不是分组吧,就两个排序而已,order by index, group
    codehz
        2
    codehz  
       123 天前
    哦写反了,反过来就对了
    zhf883680
        3
    zhf883680  
       123 天前
    说实话 你问题这么清楚 直接丢给 ai 完事..
    最近直接把要求的 json 和需要的 json 直接丢给 ai 然后把代码拿到完事
    redh
        4
    redh  
       123 天前   ❤️ 1
    ```sql
    WITH NumberedRows
    AS (SELECT [Group],
    [Index],
    Row_number()
    OVER (
    PARTITION BY [Group]
    ORDER BY [Index]) AS RowNumber
    FROM Users)
    SELECT [Group],
    [Index],
    ( ( RowNumber - 1 ) / 2 ) + 1 AS NewIndex
    FROM NumberedRows
    ORDER BY [Group],
    RowNumber;
    ```
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3127 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 20ms · UTC 14:00 · PVG 22:00 · LAX 06:00 · JFK 09:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.