Redis
该引擎允许将 ClickHouse 与 Redis 集成。由于 Redis 采用键值模型,我们强烈建议您仅以点的方式进行查询,例如 where k=xx
或 where k in (xx, xx)
。
创建表
引擎参数
host:port
— Redis 服务器地址,您可以忽略端口,默认使用 Redis 端口 6379。db_index
— Redis 数据库索引范围从 0 到 15,默认值为 0。password
— 用户密码,默认值为空字符串。pool_size
— Redis 最大连接池大小,默认值为 16。primary_key_name
- 列表中的任何列名称。
序列化
PRIMARY KEY
仅支持一个列。主键将以二进制形式序列化为 Redis 键。除了主键以外的列将按照相应的顺序以二进制形式序列化为 Redis 值。
参数也可以通过 命名集合 传递。在这种情况下,host
和 port
应该单独指定。建议在生产环境中使用这种方法。此时,通过命名集合传递给 Redis 的所有参数都是必需的。
过滤
带有 key equals
或 in filtering
的查询将被优化为从 Redis 多键查找。如果查询没有过滤键,则会发生全表扫描,这是一个重操作。
使用示例
使用简单参数在 ClickHouse 中创建一个使用 Redis
引擎的表:
或使用 命名集合:
插入数据:
查询:
更新:
请注意,主键无法更新。
删除:
截断:
异步刷新 Redis 数据库。同时 Truncate
支持 SYNC 模式。
连接:
与其他表连接。
限制
Redis 引擎也支持扫描查询,例如 where k > xx
,但它有一些限制:
- 扫描查询在极少数情况下可能会产生一些重复的键,当它正在重新哈希时。有关详细信息,请参见 Redis Scan。
- 在扫描过程中,可能会创建和删除键,因此结果数据集无法表示有效的时间点。