【ClickHouse】创建表

1、本地表

sql 复制代码
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster]
(
    name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1],
    name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2],
    ...
) ENGINE = engine

在指定的'db'数据库中创建一个名为'name'的表,如果查询中没有包含'db',则默认使用当前选择的数据库作为'db'。

括号中的表结构声明是一个包含一组列描述声明的组合。

ENGIN 为表引擎的声明。如果表引擎是支持索引的,那么可以在表引擎的参数中对其进行说明。

如果指定了IF NOT EXISTS,那么在该表已经存在的情况下,查询不会返回任何错误。在这种情况下,查询几乎不会做任何事情。

示例:

sql 复制代码
CREATE TABLE db_admin.api_user on  cluster cluster_demo (
	`id` String, 
	`name` String
) ENGINE = MergeTree ORDER BY id SETTINGS index_granularity = 8192

2、分布表:

sql 复制代码
CREATE TABLE db_admin.api_user_all on  cluster cluster_demo as db_admin.api_user
ENGINE = Distributed('cluster_demo', 'db_admin', api_user, rand())

3、复制表结构

sql 复制代码
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster] AS [db2.]name2 [ENGINE = engine]

创建一个与db2.name2具有相同结构的表,同时你可以对其指定不同的表引擎声明。如果没有表引擎声明,则创建的表将与db2.name2使用相同的表引擎。

sql 复制代码
CREATE TABLE db_admin.role as db_admin.role2 

CREATE TABLE db_admin.menu on cluster cluster_demo as db_admin.menu2

4、复制表及数据

sql 复制代码
CREATE TABLE [IF NOT EXISTS] [db.]table_name ENGINE = engine AS SELECT ...

使用指定的引擎创建一个与SELECT子句的结果具有相同结构的表,并使用SELECT子句的结果填充它。

示例:

sql 复制代码
CREATE TABLE db_admin.role ENGINE = MergeTree ORDER BY id AS select * from db_admin.role 

10、资料

相关推荐
施嘉伟2 小时前
Oracle 11g RAC ASM磁盘组剔盘、加盘实施过程
数据库·oracle
橘猫云计算机设计4 小时前
springboot基于hadoop的酷狗音乐爬虫大数据分析可视化系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·hadoop·spring boot·爬虫·python·数据分析·毕业设计
卓怡学长4 小时前
w304基于HTML5的民谣网站的设计与实现
java·前端·数据库·spring boot·spring·html5
冰^5 小时前
MySQL VS SQL Server:优缺点全解析
数据库·数据仓库·redis·sql·mysql·json·数据库开发
电商数据girl5 小时前
产品经理对于电商接口的梳理||电商接口文档梳理与接入
大数据·数据库·python·自动化·产品经理
Spring小子6 小时前
黑马点评商户查询缓存--缓存更新策略
java·数据库·redis·后端
溜溜刘@♞7 小时前
数据库之mysql优化
数据库·mysql
uwvwko8 小时前
ctfhow——web入门214~218(时间盲注开始)
前端·数据库·mysql·ctf
柯3498 小时前
Redis的过期删除策略和内存淘汰策略
数据库·redis·lfu·lru
Tiger_shl8 小时前
【Python语言基础】24、并发编程
java·数据库·python