当前位置: 首页 > wzjs >正文

不花钱建网站集团酒店网站建设

不花钱建网站,集团酒店网站建设,北京建设执业网站,贵州建设工程招投标协会网站大家好,我是全栈小5,欢迎来到《小5讲堂》。 这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解。 温馨提示:博主能力有限,理解水平有限,若有不对之处望指正! 目录 前言认识雪花ID…

大家好,我是全栈小5,欢迎来到《小5讲堂》。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 前言
  • 认识雪花ID
    • 雪花ID的核心特点
    • 雪花ID的结构(64位)
    • 雪花ID的优势
    • 雪花ID的局限性
    • 雪花ID的应用场景
    • 示例ID解析
  • 生成雪花ID
    • 使用T-SQL函数实现
    • 查看效果
  • 文章推荐

前言

在我的印象中用到这个雪花ID比较少,可能是我接触的大型项目或者开源项目比较少,同时接触到中大型分布式也比较少,基本都是自研系统,用的是自增ID和GuidValue作为唯一编号。
最近项目上使用了一套第三方框架代码,使用了雪花ID作为表的唯一主键,并且之前表没有这个字段,需要进行表迁移的同时初始化雪花ID字段值。
因此,趁这次机会简单总结下雪花ID以及在Sql Server上如何生成雪花ID。

认识雪花ID

雪花ID是Twitter开发的一种分布式唯一ID生成算法,主要用于在分布式系统中生成全局唯一的ID标识符。它的名称来源于"自然界中没有两片完全相同的雪花"这一概念,象征着每个生成的ID都是独一无二的。

雪花ID的核心特点

  1. 全局唯一性:在分布式系统中生成的ID不会重复
  2. 时间有序性:ID按照时间顺序递增
  3. 高性能:本地生成,不依赖数据库等外部系统
  4. 可解析:ID中包含的信息可以被解析出来

雪花ID的结构(64位)

标准的雪花ID由以下三部分组成(共64位):

| 1位符号位 | 41位时间戳 | 10位工作节点ID | 12位序列号 |

具体分解:

  1. 符号位(1位):始终为0,保证ID为正数
  2. 时间戳(41位):毫秒级的时间戳,可以使用约69年
    • 通常从自定义纪元开始计算(如Twitter使用2010-11-04 01:42:54 UTC)
  3. 工作节点ID(10位)
    • 通常分为5位数据中心ID + 5位机器ID
    • 最多支持32个数据中心,每个数据中心32台机器
  4. 序列号(12位):同一毫秒内的序列号,支持每毫秒生成4096个ID

雪花ID的优势

  1. 分布式友好:不同节点可以独立生成ID而不需要协调
  2. 时间有序:生成的ID按时间递增,有利于数据库索引
  3. 高性能:本地生成,不依赖网络或数据库
  4. 信息丰富:ID本身包含时间、节点等信息

雪花ID的局限性

  1. 时钟依赖:严重依赖系统时钟,时钟回拨会导致ID重复
  2. 节点ID配置:需要手动或通过外部系统分配节点ID
  3. 时间耗尽:41位时间戳大约69年后会耗尽

雪花ID的应用场景

  1. 分布式系统主键生成
  2. 订单号、交易号等业务编号
  3. 日志跟踪ID
  4. 任何需要全局唯一且有序ID的场景

示例ID解析

假设一个雪花ID:123456789012345678

转换为二进制后可以解析出:

  • 时间戳部分:可以转换为具体的生成时间
  • 工作节点部分:知道是在哪个数据中心哪台机器生成的
  • 序列号部分:知道这是该毫秒内生成的第几个ID

雪花ID因其简单高效的特性,已经成为分布式系统ID生成的经典解决方案之一。

生成雪花ID

雪花ID是Twitter提出的一种分布式ID生成算法,它生成64位的唯一ID,通常包含时间戳、工作节点ID和序列号。
在SQL Server中可以通过以下几种方式实现雪花ID的生成:

使用T-SQL函数实现

-- 创建配置表
CREATE TABLE SnowflakeConfig (MachineId BIGINT NOT NULL,DatacenterId BIGINT NOT NULL,LastTimestamp BIGINT NOT NULL,Sequence BIGINT NOT NULL,CONSTRAINT PK_SnowflakeConfig PRIMARY KEY (MachineId, DatacenterId)
);
-- 初始化配置 (机器ID和数据中心ID需要在每个节点上配置不同)
INSERT INTO SnowflakeConfig (MachineId, DatacenterId, LastTimestamp, Sequence)
VALUES (1, 1, 0, 0);
-- 创建获取当前时间戳的函数
CREATE FUNCTION GetCurrentTimestamp()
RETURNS BIGINT
AS
BEGINDECLARE @epoch DATETIME2 = '1970-01-01 00:00:00';DECLARE @now DATETIME2 = SYSUTCDATETIME();RETURN CAST(DATEDIFF_BIG(MILLISECOND, @epoch, @now) AS BIGINT);
END;
-- 创建等待下一毫秒的函数
CREATE FUNCTION TilNextMillis(@lastTimestamp BIGINT)
RETURNS BIGINT
AS
BEGINDECLARE @timestamp BIGINT;SET @timestamp = dbo.GetCurrentTimestamp();WHILE @timestamp <= @lastTimestampBEGINSET @timestamp = dbo.GetCurrentTimestamp();ENDRETURN @timestamp;
END;
GO
-- 创建计算幂的函数(替代位移操作)
CREATE FUNCTION PowerOfTwo(@exponent BIGINT)
RETURNS BIGINT
AS
BEGINRETURN CAST(POWER(CAST(2 AS FLOAT), @exponent) AS BIGINT);
END;
GO
-- 创建生成雪花ID的存储过程
CREATE PROCEDURE GenerateSnowflakeId@MachineId BIGINT = 1,@DatacenterId BIGINT = 1,@SnowflakeId BIGINT OUTPUT
AS
BEGINSET NOCOUNT ON;-- 常量定义DECLARE @Twepoch BIGINT = 1700058600000;DECLARE @MachineIdBits BIGINT = 5;DECLARE @DatacenterIdBits BIGINT = 5;DECLARE @SequenceBits BIGINT = 12;-- 使用POWER计算替代位移DECLARE @MaxMachineId BIGINT = dbo.PowerOfTwo(@MachineIdBits) - 1;DECLARE @MaxDatacenterId BIGINT = dbo.PowerOfTwo(@DatacenterIdBits) - 1;DECLARE @SequenceMask BIGINT = dbo.PowerOfTwo(@SequenceBits) - 1;DECLARE @MachineIdShift BIGINT = @SequenceBits;DECLARE @DatacenterIdShift BIGINT = @SequenceBits + @MachineIdBits;DECLARE @TimestampLeftShift BIGINT = @SequenceBits + @MachineIdBits + @DatacenterIdBits;-- 验证参数IF @MachineId > @MaxMachineId OR @MachineId < 0BEGINTHROW 50000, 'MachineId can''t be greater than maxMachineId or less than 0', 1;RETURN;ENDIF @DatacenterId > @MaxDatacenterId OR @DatacenterId < 0BEGINTHROW 50000, 'DatacenterId can''t be greater than maxDatacenterId or less than 0', 1;RETURN;END-- 使用事务确保原子性BEGIN TRANSACTION;BEGIN TRYDECLARE @LastTimestamp BIGINT;DECLARE @Sequence BIGINT;DECLARE @Timestamp BIGINT;-- 获取当前状态SELECT @LastTimestamp = LastTimestamp, @Sequence = SequenceFROM SnowflakeConfig WITH (UPDLOCK)WHERE MachineId = @MachineId AND DatacenterId = @DatacenterId;-- 获取当前时间戳SET @Timestamp = dbo.GetCurrentTimestamp();-- 检查时钟回拨IF @Timestamp < @LastTimestampBEGINROLLBACK TRANSACTION;THROW 50000, 'Clock moved backwards. Refusing to generate id', 1;RETURN;END-- 同一毫秒内生成多个IDIF @LastTimestamp = @TimestampBEGINSET @Sequence = (@Sequence + 1) & @SequenceMask;IF @Sequence = 0BEGIN-- 序列耗尽,等待下一毫秒SET @Timestamp = dbo.TilNextMillis(@LastTimestamp);ENDENDELSEBEGINSET @Sequence = 0;END-- 更新状态UPDATE SnowflakeConfigSET LastTimestamp = @Timestamp,Sequence = @SequenceWHERE MachineId = @MachineId AND DatacenterId = @DatacenterId;-- 生成ID (使用乘法替代位移)SET @SnowflakeId = (@Timestamp - @Twepoch) * dbo.PowerOfTwo(@TimestampLeftShift) +@DatacenterId * dbo.PowerOfTwo(@DatacenterIdShift) +@MachineId * dbo.PowerOfTwo(@MachineIdShift) +@Sequence;COMMIT TRANSACTION;END TRYBEGIN CATCHROLLBACK TRANSACTION;THROW;END CATCH
END;
GO

查看效果

-- 使用存储过程版本
DECLARE @Id BIGINT;
EXEC GenerateSnowflakeId @MachineId = 1, @DatacenterId = 1, @SnowflakeId = @Id OUTPUT;
SELECT @Id AS SnowflakeId;

在这里插入图片描述

文章推荐

【Sql Server】使用row_number over方式进行表分页,数据量达到五千多条记录后,查询变慢需要20多秒的解决方案

【Sql Server】随机查询一条表记录,并重重温回顾下自定义函数的封装和使用

【Sql Server】锁表如何解锁,模拟会话事务方式锁定一个表然后进行解锁

【Sql Server】通过Sql语句批量处理数据,使用变量且遍历数据进行逻辑处理

【新星计划回顾】第六篇学习计划-通过自定义函数和存储过程模拟MD5数据

【新星计划回顾】第四篇学习计划-自定义函数、存储过程、随机值知识点

【Sql Server】Update中的From语句,以及常见更新操作方式

【Sql server】假设有三个字段a,b,c 以a和b分组,如何查询a和b唯一,但是c不同的记录

【Sql Server】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。


文章转载自:

http://I9ovdnQU.csjps.cn
http://LMq1uOuK.csjps.cn
http://YNYYuCK6.csjps.cn
http://xUdpf3yX.csjps.cn
http://a4y7E416.csjps.cn
http://GGLBOBx8.csjps.cn
http://Bxg6wTEG.csjps.cn
http://q8VXaIzZ.csjps.cn
http://aMSOVjQx.csjps.cn
http://PGp1q593.csjps.cn
http://gXl5Hn6G.csjps.cn
http://B4rZyPIe.csjps.cn
http://eYDcL4rl.csjps.cn
http://fg4qaKPR.csjps.cn
http://Vc1RKIJH.csjps.cn
http://LguMagcT.csjps.cn
http://LxxHx5jW.csjps.cn
http://LJg06L6y.csjps.cn
http://1wESMxvQ.csjps.cn
http://j73CbXg9.csjps.cn
http://2OcH54CX.csjps.cn
http://I9y8L2xe.csjps.cn
http://6huyoQOp.csjps.cn
http://MOGwVcH9.csjps.cn
http://wFmyj7O1.csjps.cn
http://a3CcZrbd.csjps.cn
http://zxYZU08O.csjps.cn
http://8iajvNbF.csjps.cn
http://64zZNk9k.csjps.cn
http://8gq17mWl.csjps.cn
http://www.dtcms.com/wzjs/667935.html

相关文章:

  • 保定网站制作价格专业提供网站建设服务的企业
  • 建设化妆品网站服务网站建设功能seo
  • 网站的说服力学做美食视频在哪个网站
  • 山东省建设职业教育集团网站赚钱的十大个人网站
  • 自己做网站接入微信和支付宝彩页设计素材
  • 医院系统网站建设上市公司网站建设报价
  • 茂名市城市建设档案馆网站多少钱的英文怎么写
  • 网站托管怎做外贸建站公司排名
  • 如何做一个好网站wordpress主题开发导航制作
  • 网站运营推广主要做什么的pc三合一网站
  • 西安网络营销学习网站河南省建设厅官方网站 吴浩
  • 湛江哪家公司建网站最好鞍山市住房和城乡建设网站
  • 淘宝客网站制作视频教程英雄联盟视频网站源码
  • 免费资料网站网址下载做外卖那些网站好
  • 做板子焊接的网站的公司名字确定建设电子商务网站目的
  • 招聘网站做一下要多少钱加盟型网站制作
  • ps扩展插件网站互联网网站建设价格
  • 织梦的网站关键词商标设计怎么收费
  • 电脑做视频的网站比较好手机编程工具
  • 6做网站网站建设初步认识的实训体会
  • 兰州装修公司哪家口碑好seo排名的方法
  • html手机网站如何制作网站建设和运维单位责任
  • 泰兴企业网站建设大型网站建设定制开发
  • 白家乐网站怎么建站wordpress手机版本
  • php如何网站做修改怎么联系网站开发团队
  • 莱芜环保网站湖南餐饮网站建设
  • 怎样凡科建设网站新增备案网站负责人
  • 广州网站建设公司哪个好国字型网页布局图片
  • 网站开发线上有什么好的书写网站
  • 中国招标建设信息网站乐清城市网