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

简介: 本文将介绍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;
相关文章
|
2月前
|
存储 物联网 Serverless
理想汽车基于 Hologres + Flink 构建万亿级车联网信号实时分析平台
理想汽车携手阿里云Hologres+Flink,打造万亿级车联网实时分析平台。面对百万余辆智能车、每秒百万级信号上报的挑战,通过存算分离、冷热分层、流批一体等创新,实现写入性能提升200%、查询QPS超万、成本降低40%,支撑数字孪生、智能诊断等高实时业务,构建高可用、弹性伸缩、低成本的下一代数据底座。
221 4
|
2月前
|
缓存 数据可视化 定位技术
快递鸟快递API技术指南:获取物流轨迹信息与轨迹地图的解决方案
在当今电商竞争激烈的环境中,物流体验已成为提升用户满意度的关键因素。研究表明,超过 75% 的消费者会因物流信息不透明而放弃下单。
567 1
|
2月前
|
人工智能 缓存 数据可视化
复盘:利用 Coze+Kimi 搭建自动财报分析“金融助理”的方法
本文手把手教你如何利用Coze与Kimi搭建智能财报分析助手。从环境部署、工作流设计到专业提示词编写,完整展示5分钟内实现财务指标计算、趋势分析和风险提示的自动化流程,有效提升投研效率。
|
2月前
|
传感器 编解码 数据挖掘
ASTER 全球数字高程模型 V003
ASTER全球数字高程模型V003(ASTGTM)由NASA与日本METI合作生成,覆盖北纬83°至南纬83°,空间分辨率约30米。基于2000–2013年ASTER立体影像自动处理,融合超188万场景,优化水体与地形精度,提供DEM与场景数量图层,数据无显著空隙,适用于多领域地形分析。
249 7
|
3月前
|
人工智能
四大公益场景,20万奖金!AI开源公益创新挑战赛邀你一起「小有可为」
四大公益场景,20万奖金!AI开源公益创新挑战赛邀你一起「小有可为」
222 8
|
9月前
|
人工智能 监控 安全
多领域实用工具,提升效率与协作的法宝
精选多领域实用工具,提升效率与协作。TinyTask:32KB轻量自动化工具,适合基础重复操作;Qdown:基于Aria2内核的全能下载器,内存占用仅30MB;燃精灵:微信空号检测软件,助你精准抓取潜在客户;Prezi:非线性动态演示工具,支持AI生成大纲与多人协作;向日葵:跨平台远程控制,提供安全高效的远程办公解决方案。善用这些工具,优化工作流程,释放生产力。
199 0
|
7月前
|
前端开发 JavaScript
借助 CodeBuddy,轻松打造「一分钟冥想」App
有一天,我突发奇想,想做一个非常简单但美观的应用:**「一分钟冥想」**。它不需要繁复的交互,也不涉及音频流媒体或账户体系,只是一个安静、优雅的页面,引导用户专注呼吸,放松身心,完成短暂而高效的 60 秒冥想。我把这个想法交给了 CodeBuddy,启动了一个全新的 UniApp 项目,开始了这段愉快的前端实现之旅。 --- ## 需求分析:越简单的产品越考验设计 最初我和 CodeBuddy 明确了目标:**打造一个拥有 SVG 呼吸圈动画、渐变背景、引导语音(可以占位)、简约 UI 和播放按钮的冥想页面。** CodeBuddy 快速分析了项目范围和复杂度,这将是一个前端单页面
175 4
借助 CodeBuddy,轻松打造「一分钟冥想」App
|
7月前
|
前端开发 安全 JavaScript
《驾驭Hybrid框架:解锁Web与原生融合的高阶实践》
Hybrid框架通过融合Web与原生优势,打造高效且优质的用户体验。JSBridge实现Web与原生间的高效通信,优化渲染性能以平衡灵活性与硬件利用,同时注重资源管理、安全防护及兼容性处理。开发者需综合考虑这些方面,巧妙设计,充分发挥Hybrid框架潜力,满足多样化场景需求。
210 24
|
11月前
|
XML 机器学习/深度学习 人工智能
使用 OpenCV 和 Python 轻松实现人脸检测
本文介绍如何使用OpenCV和Python实现人脸检测。首先,确保安装了OpenCV库并加载预训练的Haar特征模型。接着,通过读取图像或视频帧,将其转换为灰度图并使用`detectMultiScale`方法进行人脸检测。检测到的人脸用矩形框标出并显示。优化方法包括调整参数、多尺度检测及使用更先进模型。人脸检测是计算机视觉的基础技术,具有广泛应用前景。
532 10
|
存储 容灾 开发工具