请问如果目标表没有指定主键,PolarDB-X拆分规则是什么?
如果目标表没有指定主键,PolarDB-X 会采用以下的规则进行数据分片:
Round-Robin 分片:默认按照数据插入时间进行轮询分片。每个 shard 节点分配相等数量的数据块,插入数据时会根据 Round-Robin 算法将数据均匀地分配到各个 shard 节点中。
Bloom Filter 分片:通过 Bloom Filter 算法将数据映射成位向量,增加分片后的查询过滤效率,提高查询性能,减少查询次数。
请注意,根据数据特点和查询需求,推荐在表中指定适当的主键或者按照业务规则来对表进行分区设计,这样会更好地缩短查询时间,提高查询性能。
在拆分策略上,系统会默认选择主键进行拆分,对于没有主键的表,系统会增加隐藏主键。
如果目标表没有指定主键,PolarDB-X会根据表的分布键进行拆分。如果表没有指定分布键,则会使用默认的分布键进行拆分。拆分规则是将表的数据按照分布键的值进行分片,每个分片存储在不同的节点上。这样可以实现数据的并行处理和高可用性。
您好,如果目标表没有指定主键,PolarDB-X会启用隐式主键并将其作为拆分键,该主键为BIGINT类型的自增主键,且对用户不可见。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 采用 Shared-nothing 与存储计算分离架构,支持水平扩展、分布式事务、混合负载等能力,100%兼容MySQL。 2021年开源,开源历程及更多信息访问:OpenPolarDB.com/about