在Snowflake SQL中向表添加行ID [英] Adding row IDs to table in Snowflake SQL

查看:25
本文介绍了在Snowflake SQL中向表添加行ID的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

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

我使用此查询创建了一个重复的表:

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’添加到非空表‘Duplates’

我现在有点缺乏想法,因为关于Snowflake SQL的讨论还不是很广泛,Snowflake的帮助页面对我也没有帮助。

推荐答案

一个简单的方法是使用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;

这篇关于在Snowflake SQL中向表添加行ID的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆