Clickhouse(7)---TinyLog引擎

本文介绍ClickHouse中的TinyLog引擎特点及使用方法。TinyLog是最简单的表引擎之一,适用于快速写入小表并整体读取场景。文章详细解释了TinyLog的数据存储方式、限制条件以及SQL操作示例。
摘要由CSDN通过智能技术生成

Clickhouse表引擎

表引擎(即表的类型)决定了:

  • 数据的存储方式和位置,写到哪里以及从哪里读取数据
  • 支持哪些查询以及如何支持。
  • 并发数据访问。
  • 索引的使用(如果存在)。
  • 是否可以执行多线程请求。
  • 数据复制参数,是否可以存储数据副本。
  • 分布式引擎 实现分布式

TinyLog引擎

  • Log家族具有最小功能的[轻量级引擎。当需要快速写入许多小表(最多约100万行)并在以后整体读取它们时,该类型的引擎是最有效的。
  • 最简单的表引擎,用于将数据存储在磁盘上。每列都存储在单独的压缩文件中,写入时,数据将附加到文件末尾。该引擎没有并发控制
    1、最简单的引擎
    2、没有索引,没有标记块
    3、写是追加写
    4、数据以列字段文件存储
    5、不允许同时读写

底层数据存储

-- 建表 
create table test_tinylog(
	id UInt8 ,
    name String ,
    age UInt8
)engine=TinyLog ;
-- 查看表结构
desc test_tinylog ;
-- 查看建表语句 
SHOW CREATE TABLE test_tinylog ;
-- 插入数据 
insert into test_tinylog values(1,'liubei',45),(2,'guanyu',43),(3,'zhangfei',41) ;

SELECT *
FROM test_tinylog

┌─id─┬─name─────┬─age─┐
│  1 │ liubei   │  45 │
│  2 │ guanyu   │  43 │
│  3 │ zhangfei │  41 │
└────┴──────────┴─────┘

第一次插入数据,文件存储结构。此种引擎少了"_marks.mrk"文件。只记录了列数据,和长度JSON
在这里插入图片描述
第二次插入数据,文件存储结构 。可以看出数据是在文件追加的数据
在这里插入图片描述

不允许同时读写

此引擎禁止使用 insert into t select * from t
SQL语法没有问题,但是底层数据会瘫痪。如果使用会造成底层数据瘫痪,并且查询数据和删除表无法执行。

如果执行此语句之后删除表。需要把数据和元数据文件都删除重启服务。

rm -rf xxxxxxx

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Abner G

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值