TinyLog引擎
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