开发指南—函数—拆分函数—RIGHT_SHIFT

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介: 本文将介绍RIGHT_SHIFT函数的使用方式

描述

根据分库键的键值(键值必须是整数)有符号地向右移二进制指定的位数(位数可通过DDL指定),然后将得到的整数值按分库(表)数目取余。

使用限制

拆分键的类型必须整数类型。

使用场景

当拆分键大部分键值的低位部分区分度比较低而高位部分区分度比较高时,则适用于通过此拆分函数提高散列结果的均匀度。

例如有4个拆分键的键值,分别为0x0100、0x0200、0x0300和0x0400, 这4个值的第8位部分都是0。通常一些业务后N位可能只是一些业务上的标志位,如果直接对键值进行取余散列,其散列效果可能会比较差。但如果通过RIGHT_SHIFT(shardKey, 8)将拆分键的值进行二进制右移8位,则分别变成了0x01、0x02、0x03和0x04,这样的散列效果就会比较均匀(若分4个库,刚好可以每个值对应一个分库)。

使用示例

假设需要将ID作为拆分键,并将ID的值向右移二进制4位的值作为哈希值,则可以如下建表:


create table test_hash_tb (    
    id int, 
    name varchar(30) DEFAULT NULL,  
    create_time datetime DEFAULT NULL,
    primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 
dbpartition by RIGHT_SHIFT(id, 8) 
tbpartition by RIGHT_SHIFT(id, 8) tbpartitions 4;
相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
SQL 存储 算法
TPCC测试究竟意味着什么
最近分布式数据库领域可谓非常之火(也可能是非常之卷),特别的,很多人会关注TPCC的测试结果,也有不少产品会投入很多精力在TPCC的优化上。 我们首先需要搞明白的是,我们从TPCC的测试结果,究竟能得出对这个分布式数据库什么样的评价。
3744 3
|
网络性能优化
【AXI】解读AXI协议的额外信号(QOS信号,REGION信号,与USER信号)
【AXI】解读AXI协议的额外信号(QOS信号,REGION信号,与USER信号)
【AXI】解读AXI协议的额外信号(QOS信号,REGION信号,与USER信号)
|
11月前
|
存储 监控 Ubuntu
Linux下sysstat安装使用图文详解
Linux下sysstat安装使用图文详解
315 0
Linux下sysstat安装使用图文详解
|
6月前
|
SQL Oracle 关系型数据库
oracle中日期循环
oracle中日期循环
329 0
开发指南—函数—拆分函数—RIGHT_SHIFT
本文将介绍RIGHT_SHIFT函数的使用方式
开发指南—函数—拆分函数—YYYYWEEK
本文将介绍YYYYWEEK函数的使用方式。
开发指南—函数—拆分函数—YYYYDD
本文介绍YYYYDD函数的使用方式。
126 0
开发指南—函数—拆分函数—MMDD
本文介绍MMDD函数的使用方式。
111 0
开发指南—函数—拆分函数—YYYYMM
本文介绍YYYYMM函数的使用方式
103 0
|
存储 Web App开发 网络协议
YUV的plannar,packet及semi-planar格式及RGB
YUV的plannar,packet及semi-planar格式及RGB
202 0
YUV的plannar,packet及semi-planar格式及RGB