程序中为数据库uniqueidentifier类型字段【TSQL中用newid()赋值或以newsequentialid ()为Default值】生成有序的GUID

C#产生有序的GUID 

    public class GuidEx
    {
        /// <summary>
        /// 产生有序的GUID (用于解决默认无序的GUID给数据库聚集索引字段造成的性能问题)
        /// </summary>
        /// <returns></returns>
        public static string GenerateOrderly(int index = 0)
        {
            byte[] guidArray = Guid.NewGuid().ToByteArray();

            DateTime baseDate = new DateTime(1900, 1, 1);
            DateTime now = DateTime.Now;

            TimeSpan days = new TimeSpan(now.Ticks - baseDate.Ticks);

            TimeSpan msecs = new TimeSpan(now.Ticks - (new DateTime(now.Year, now.Month, now.Day).Ticks));
            byte[] daysArray = BitConverter.GetBytes(days.Days);
            byte[] msecsArray = BitConverter.GetBytes((long)(msecs.TotalMilliseconds + index));

            Array.Copy(daysArray, 0, guidArray, 2, 2);
            //毫秒高位
            Array.Copy(msecsArray, 2, guidArray, 0, 2);
            //毫秒低位
            Array.Copy(msecsArray, 0, guidArray, 4, 2);
            return new Guid(guidArray).ToString();
        }



        /// <summary>
        /// 产生随机的GUID
        /// </summary>
        /// <returns></returns>
        public static string GuidRandom()
        {
            return Guid.NewGuid().ToString();
        }
    }

相关知识点 (本人另一篇文章):

理解 newid ()和 newsequentialid ()https://blog.csdn.net/carcarrot/article/details/103212815 

注意:NEWSEQUENTIALID()只能在创建或修改表时定义为默认值时有效(该函数能在数据库层面默认生成有序的GUID值)

关于uniqueidentifier 数据类型

uniqueidentifier 数据类型可存储 16 字节的二进制值,其作用与全局唯一标识符 (GUID) 一样。GUID 是唯一的二进制数;世界上的任何两台计算机都不会生成重复的 GUID 值。GUID 主要用于在拥有多个节点、多台计算机的网络中,分配必须具有唯一性的标识符。 

可以按下列方式指定 uniqueidentifier 常量:

  • 字符串格式: '6F9619FF-8B86-D011-B42D-00C04FC964FF'

  • 二进制格式: 0xff19966f868b11d0b42d00c04fc964ff (与上面的字符串表示的值相同)

uniqueidentifier 为 16 字节时,其数据类型比其他数据类型(例如 4 字节的整数)大。这意味着使用 uniqueidentifier 键生成索引的速度相对慢于使用 int 键生成索引的速度。在不要求全局唯一性或首选使用按序列增加的键时,请考虑使用 IDENTITY 属性 (引自:https://learn.microsoft.com/zh-cn/previous-versions/sql/sql-server-2008-r2/ms190215(v=sql.105)

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值