全部产品
分布式关系型数据库 DRDS

HASH

更新时间:2017-08-04 15:39:41   分享:   

使用要求

  • 拆分键的数据类型必须是整数类型或字符串类型。

  • DRDS 实例的版本必须是 5.1.28-1320920 及其以上的版本。DRDS 版本说明请参考文档版本说明

路由方式

根据分库键的键值直接按分库数取余(如果是键值是字符串,则字符串会被计算成哈希值再进行计算),完成路由计算,例如: HASH(‘8’) 等价于 8 % D,(D是分库数目)。

使用场景

  • 适合于需要按用户 ID 或订单 ID 进行分库的场景。

  • 适合于拆分键是字符串类型的场景。

使用示例

假设用户需要对 ID 列按 HASH 函数进行分库不分表,则应该使用如下的建表 DDL:

  1. create table test_hash_tb (
  2. id int,
  3. name varchar(30) DEFAULT NULL,
  4. create_time datetime DEFAULT NULL,
  5. primary key(id)
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 dbpartition by HASH(ID);

注意事项

哈希算法是简单取模,要求拆分列的值的自身分布均衡才能保证哈希均衡。

本文导读目录
本文导读目录
以上内容是否对您有帮助?