clickhouse自增id的处理

msyql 中创建数据表的时候可以通过AUTO_INCREMENT 来实现,clickhouse中可以通过其他方式来处理

一、 默认值

创建表时可以实用默认值,该列值可以自动递增。如下所示

sql 复制代码
CREATE TABLE my_table (
id UInt32 DEFAULT IDENTITY(AUTO_INCREMENT),
name String
)
ENGINE = MergeTree()
ORDER BY id;

在上述示例中,id列被设置为自增序号,并且使用了IDENTITY(AUTO_INCREMENT)修饰符来实现自增。插入新行时,无需为id列指定值,它将自动递增。

二、 序列函数

另一种实现自增序号的方法是使用序列函数。ClickHouse提供了sequence()函数,可以生成一个序列值。通过将序列值插入到表中,可以实现自增序号的效果。例如:

sql 复制代码
CREATE TABLE my_table (
id UInt32,
name String
)
ENGINE = MergeTree()
ORDER BY id;
INSERT INTO my_table (id, name) VALUES (sequence(1, 10), 'John');

在上述示例中,首先创建了一个名为my_table的表,其中包含一个名为id的自增序号列。然后,使用sequence(1, 10)生成了一个包含1到10的序列值,并将这些值插入到表中。这样,每行记录的id列都将具有唯一的自增序号。

三、存储过程增加递增id

通过 rowNumberInAllBlocks() 函数,可以生成自增的数字id ,直接使用

sql 复制代码
SELECT  rowNumberInAllBlocks()

四、 uuid自动增加

给表设置uuid字段,使用 generateUUIDv4()函数赋予默认值。

sql 复制代码
select generateUUIDv4()
相关推荐
小陈工2 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
科技小花6 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain6 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希7 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神7 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员7 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java7 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿7 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴7 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存