4

我需要将具有唯一整数/哈希的列添加到表中以用作行 ID。

我用这个查询创建了一个表 DUPLICATES:

CREATE TABLE duplicates AS
SELECT
    "a", "b", COUNT(*) as _count
FROM
    "table"
GROUP BY
    "a", "b"
HAVING 
    _count > 1
ORDER BY 
 _count desc

现在我需要为每一行添加一个包含唯一 ID 的列。我试过ALTER TABLE DUPLICATES ADD 'id' int identity(1,1)了,但是这会返回:SQL 编译错误:无法将具有非常量默认值的列 'id' 添加到非空表 'DUPLICATES'

我现在有点缺乏想法,因为关于 Snowflake SQL 的讨论还没有普及,而且 Snowflake 的帮助页面也没有帮助我。

4

2 回答 2

5

一种简单的方法是使用row_number()

CREATE TABLE duplicates AS
    SELECT ROW_NUMBER() OVER (ORDER BY COUNT(*) DESC) as id,
           "a", "b", COUNT(*) as _count
    FROM "table"
    GROUP BY "a", "b"
    HAVING  _count > 1
    ORDER BY _count desc;
于 2018-04-24T21:23:30.790 回答
3

在 Snowflake 中执行此操作的最简单方法是使用序列。非常简单,但它们可用于为主键或任何需要唯一值的列生成值。如何使用:

https://docs.snowflake.net/manuals/user-guide/querying-sequences.html

于 2018-05-07T19:56:30.617 回答