h3xz
V2EX  ›  数据库

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

  •  
  •   h3xz · Jul 25, 2024 · 1962 views
    This topic created in 674 days ago, the information mentioned may be changed or developed.

    在 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 replies    2024-07-25 18:45:56 +08:00
    codehz
        1
    codehz  
       Jul 25, 2024 via iPhone
    这也不是分组吧,就两个排序而已,order by index, group
    codehz
        2
    codehz  
       Jul 25, 2024
    哦写反了,反过来就对了
    zhf883680
        3
    zhf883680  
       Jul 25, 2024
    说实话 你问题这么清楚 直接丢给 ai 完事..
    最近直接把要求的 json 和需要的 json 直接丢给 ai 然后把代码拿到完事
    redh
        4
    redh  
       Jul 25, 2024   ❤️ 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;
    ```
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2893 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 43ms · UTC 08:41 · PVG 16:41 · LAX 01:41 · JFK 04:41
    ♥ Do have faith in what you're doing.