ClickHouse--08--SQL DDL 操作

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • [SQL DDL 操作](#SQL DDL 操作)
    • [1 创建库](#1 创建库)
    • [2 查看数据库](#2 查看数据库)
    • [3 删除库](#3 删除库)
    • [4 创建表](#4 创建表)
    • [5 查看表](#5 查看表)
    • [6 查看表的定义](#6 查看表的定义)
    • [7 查看表的字段](#7 查看表的字段)
    • [8 删除表](#8 删除表)
    • [9 修改表](#9 修改表)
      • [9.1 添加列](#9.1 添加列)
      • [9.2 删除列](#9.2 删除列)
      • [9.3 清空列](#9.3 清空列)
      • [9.4 给列修改注释](#9.4 给列修改注释)
      • [9.5 修改列类型](#9.5 修改列类型)
    • [10 给表重命名](#10 给表重命名)
  • [分区表的 DDL 操作](#分区表的 DDL 操作)

SQL DDL 操作

DDL:Data Definition Language,数据库定义语言。

  1. 在 ClickHouse 中,DDL 语言中修改表结构仅支持 Merge 表引擎、Distributed 表引擎及 MergeTree
    家族的表引擎
  2. SQL 中的库、表、字段严格区分大小写

1 创建库

2 查看数据库

3 删除库



4 创建表

创建表的基本语法:

示例:


5 查看表

6 查看表的定义


7 查看表的字段

8 删除表

9 修改表

9.1 添加列

9.2 删除列

9.3 清空列

注意,不能清空排序、主键、分区字段


9.4 给列修改注释

9.5 修改列类型

10 给表重命名


分区表的 DDL 操作

  • ClickHouse 中只有 MergeTree 家族引擎下的表才能分区。这里说的分区表就是MergeTree 家族表引擎对应的分区表。

1.查看分区信息


2.卸载分区

将指定分区的数据移动到 detached 目录。服务器会忽略被分离的数据分区。只有当你使用 ATTACH 时,服务器才会知晓这部分数据。当执行操作以后,可以对 detached 目录的数据进行任意操作,例如删除文件,或者放着不管。


3.装载分区

  • 我们可以将已经卸载的分区重新装载到对应的表分区中。这里就是将 detached 目录 中的数据重新移动到对应的表数据目录下。
  • 也可以将卸载的分区数据加载到其他表中,但是这个表需要与原来的表具有相同的表结构及相同的分区字段。


4.删除分区

  • ClickHouse 中的分区表,可以针对分区表删除某个分区,之后再导入当前分区的数 据,以达到数据更新的目的。
  • 执行删除分区命名是直接将对应分区数据删除,不会放入 detached 目录。该操作会 将分区标记为不活跃的,然后在大约 10 分钟内删除全部数据。

5.替换分区

替换分区支持将 table1 表的分区数据复制到 table2 表,并替换 table2 表的已有分区。table1 表中分区数据不会被删除,table1 和 table2 表必须要有相同的表结构且分区字段相同。这个操作经常用作数据备份、表数据同步操作。

6.移动分区

该 操 作 将 table_source 表 的 数 据 分 区 移 动 到 table_dest 表 , 并 删 除table_source 表的数据。

7.重置分区列

重置指定分区的特定列的值,就是将指定分区下某列的数据清空,如果建表时使用了DEFAULT 语句,该操作会将列的值重置为该默认值



相关推荐
薛晓刚1 小时前
当MySQL的int不够用了
数据库
SelectDB技术团队2 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术
星空下的曙光2 小时前
mysql 命令语法操作篇 数据库约束有哪些 怎么使用
数据库·mysql
小楓12012 小时前
MySQL數據庫開發教學(一) 基本架構
数据库·后端·mysql
染落林间色2 小时前
达梦数据库-实时主备集群部署详解(附图文)手工搭建一主一备数据守护集群DW
数据库·sql
颜颜yan_2 小时前
企业级时序数据库选型指南:从传统架构向智能时序数据管理的转型之路
数据库·架构·时序数据库
lichenyang4532 小时前
管理项目服务器连接数据库
数据库·后端
沙振宇3 小时前
【数据库】通过‌phpMyAdmin‌管理Mysql数据
数据库·mysql
杨云龙UP3 小时前
CentOS Linux 7 (Core)上部署Oracle 11g、19C RAC详细图文教程
数据库·oracle
ezl1fe4 小时前
RAG 每日一技(十八):手写SQL-RAG太累?LangChain的SQL智能体(Agent)前来救驾!
数据库·人工智能·后端