it编程 > 数据库 > Mysql

MySQL生成雪花算法ID的实现示例

64人参与 2026-05-09 Mysql

简单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内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

Nginx的proxy_pass命令使用

05-09

prometheus监控nginx的实现步骤

05-09

Nginx的版本平滑升级和回退的实现

05-09

MySQL DDL数据定义语言示例总结

05-09

Docker搭建Mysql8的主从复制实例代码

05-09

服务从mysql迁移达梦数据库的实现方案

05-09

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论