我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL 雪花Id函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL 雪花Id函数

环境 MySQL5.7

简介

snowflake是Twitter开源的分布式ID生成算法,结果是64bit的Long类型的ID,有着全局唯一和有序递增的特点。

show

  • 最高位是符号位,因为生成的 ID 总是正数,始终为0,不可用。
  • 41位的时间序列,精确到毫秒级,41位的长度可以使用69年。时间位还有一个很重要的作用是可以根据时间进行排序。
  • 10位的机器标识,10位的长度最多支持部署1024个节点。
  • 12位的计数序列号,序列号即一系列的自增ID,可以支持同一节点同一毫秒生成多个ID序号,12位的计数序列号支持每个节点每毫秒产生4096个ID序号。
    缺点也是有的,就是强依赖机器时钟,如果机器上时钟回拨,有可能会导致主键重复的问题。

雪花Id

脚本根据 github:https://github.com/yitter/IdGenerator/tree/master/SQL 的SQL Server 版移植而来

雪花Id脚本

CREATE FUNCTION `SnowId`() RETURNS bigint(20)BEGINDECLARE b_current_time BIGINT;DECLARE b_time_tick BIGINT;DECLARE i_work_id INT;DECLARE i_work_id_big_length INT;DECLARE i_seq_big_length INT;DECLARE f_random FLOAT;DECLARE b_res BIGINT;SET i_work_id = 1;SET i_work_id_big_length = 4;SET i_seq_big_length = 8;SET b_current_time = (REPLACE(UNIX_TIMESTAMP(CURRENT_TIMESTAMP(3)),'.','')) + 0;SET b_time_tick = b_current_time - 1582136402000;SET f_random = RAND();SET b_res = b_time_tick * POWER(2, i_work_id_big_length + i_seq_big_length) + i_work_id * POWER(2, i_seq_big_length) + (5 + round((POWER(2, i_seq_big_length)-1) * f_random, 0));RETURN b_res;END

测试脚本

创建一个名为TestSnowId存储过程
内容:
定义了一个int变量i默认为1;
创建了一个临时表temp_numbers用于存储生成的SnowId;
循环5000次,并将SnowId添加到temp_numbers表内;
查询temp_numbers表内数据;
删除临时表;

CREATE PROCEDURE `TestSnowId` () BEGINDECLARE i INT DEFAULT 1;CREATE TEMPORARY TABLE IF NOT EXISTS temp_numbers ( number BIGINT );WHILE i <= 5000 DO    INSERT INTO temp_numbers ( number ) VALUES (SnowId ());SET i = i + 1;END WHILE;SELECT * FROM temp_numbers;DROP TEMPORARY TABLE IF EXISTS temp_numbers;END

使用

调用语句

SELECT SnowId();

getSnowId

测试是否重复

CALL TestSnowId();

test

来源地址:https://blog.csdn.net/qq_45026510/article/details/132337806

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL 雪花Id函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Mysql数据库自增id、uuid与雪花id详解

目录概念介绍三种主键聚簇索引与非聚簇索引自增iduuid雪花id与应用总结概念介绍三种主键自增id :1 2 3 4 5……uuid :UUID是Universally Unique Identifier的
2023-02-28

springboot中使用雪花算法生成雪花ID

本文主要介绍了springboot中使用雪花算法生成雪花ID,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-03-19

Mysql数据库自增id、uuid与雪花id实例分析

这篇“Mysql数据库自增id、uuid与雪花id实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mysql数据库自增
2023-07-05

springboot中如何使用雪花算法生成雪花ID

这篇文章主要介绍“springboot中如何使用雪花算法生成雪花ID”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“springboot中如何使用雪花算法生成雪花ID”文章能帮助大家解决问题。1、什么
2023-07-05

MyBatis使用雪花ID怎么实现

这篇文章主要介绍了MyBatis使用雪花ID怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MyBatis使用雪花ID怎么实现文章都会有所收获,下面我们一起来看看吧。一、实现MyBatis ID构建接口@
2023-06-29

mybatisplus雪花算法生成Id怎么使用

这篇文章主要讲解了“mybatisplus雪花算法生成Id怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mybatisplus雪花算法生成Id怎么使用”吧!雪花算法实战1.建表DRO
2023-07-02

Java使用雪花id生成算法详解

SnowFlake算法,是Twitter开源的分布式id生成算法,在2014年开源,开源的版本由scala编写。其核心思想就是-使用一个64bit的long型的数字作为全局唯一id
2022-12-20

PHP怎么利用雪花算法生成唯一ID

这篇文章主要讲解了“PHP怎么利用雪花算法生成唯一ID”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP怎么利用雪花算法生成唯一ID”吧!一、雪花算法原理解析1. 分布式ID常见生成策略分
2023-06-30

mybatis-plus怎么使用雪花算法ID生成策略

本篇内容介绍了“mybatis-plus怎么使用雪花算法ID生成策略”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!mybatis-plus
2023-06-21

Java怎么通过手写分布式雪花SnowFlake生成ID

本文小编为大家详细介绍“Java怎么通过手写分布式雪花SnowFlake生成ID”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java怎么通过手写分布式雪花SnowFlake生成ID”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一
2023-06-29

基于雪花算法实现增强版ID生成器详解

这篇文章主要为大家详细介绍了如何基于雪花算法实现增强版ID生成器,文中的示例代码讲解详细,对我们学习具有一定的借鉴价值,需要的可以了解一下
2022-11-13

编程热搜

目录