简单sql版:
select
-- 1. 42位 毫秒级时间戳(高位):当前时间戳 *1000 转毫秒,左移22位留出后面空间
floor(unix_timestamp(now(3)) * 1000) << 22
-- 2. 10位 机器id(中间位):固定机器标识 c0wd7eoh,转为数字后左移12位
| crc32('c0wd7eoh') % 1024 << 12
-- 3. 12位 序列号(低位):同一毫秒内的自增序列,这里用随机数模拟(真实场景用自增变量)
| floor(rand() * 4096) as id;
结果示例值:7458326199558728174
创建函数:
drop function if exists snowflake_id;
delimiter $$
create function snowflake_id(worker_name varchar(50))
returns bigint unsigned
no sql
begin
declare now_ms bigint unsigned;
declare worker_id int unsigned;
set worker_id = crc32(worker_name) % 1024;
wait_loop: while true do
set now_ms = floor(unix_timestamp(now(3)) * 1000);
set @last_ms = ifnull(@last_ms, now_ms);
set @seq = ifnull(@seq, 0);
-- 新毫秒 → 重置序列号
if now_ms <> @last_ms then
set @seq = 0;
set @last_ms = now_ms;
end if;
-- 标准雪花:每毫秒 0~4095
if @seq <= 4095 then
set @seq = @seq + 1;
leave wait_loop;
end if;
end while wait_loop;
return (now_ms << 22) | (worker_id << 12) | @seq;
end$$
delimiter ;
使用:
# 参数为机器码,给个随机数就行,例:
select snowflake_id('0bpb3rbc');
结果示例值:7458326199558728174
到此这篇关于mysql生成雪花算法id的实现示例的文章就介绍到这了,更多相关mysql生成雪花算法id内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论