c#中的GUID

GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成GUID的API。生成算法很有意思,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。GUID的唯一缺陷在于生成的结果串会比较大。”
1. 一个GUID为一个128位的整数(16字节),在使用唯一标识符的情况下,你可以在所有计算机和网络之间使用这一整数。

2. GUID 的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字。例如:337c7f2b-7a34-4f50-9141-bab9e6478cc8 即为有效的 GUID 值。

3. 世界上(Koffer注:应该是地球上)的任何两台计算机都不会生成重复的 GUID 值。GUID 主要用于在拥有多个节点、多台计算机的网络或系统中,分配必须具有唯一性的标识符。

4. 在 Windows 平台上,GUID 应用非常广泛:注册表、类及接口标识、数据库、甚至自动生成的机器名、目录名等。

 

.NET中使用GUID

GUID 在 .NET 中使用非常广泛,而且 .NET Framework 提供了专门 Guid 基础结构。
Guid 结构的常用法包括:
1) Guid.NewGUID()
生成一个新的 GUID 唯一值
2) Guid.ToString()
将 GUID 值转换成字符串,便于处理
3)构造函数 Guid(string)
由 string 生成 Guid 结构,其中string 可以为大写,也可以为小写,可以包含两端的定界符“{}”或“()”,甚至可以省略中间的“-”,Guid 结构的构造函数有很多,其它构造用法并不常用。

.NET Framework 中可以使用类 GuidConverter 提供将 Guid 结构与各种其他表示形式相互转换的类型转换器。

 

在C#中生成一个GUID

处理一个唯一标识符使得存储和获得信息变得更加容易。在处理一个数据库中这一功能变得尤其有用,因为一个GUID能够操作一个主键。

同样,SQL Server也很好地集成了GUID的用途。SQL Server数据类型uniqueidentifier能够存储一个GUID数值。你可以通过使用NEWID()函数在SQL Server中生成这一数值,或者可以在SQL Server之外生成GUID,然后再手动地插入这一数值。

在.NET中,后面一种方法显得更加直接。.NET Framework中的基本System类包括GUID数值类型。除此之外,这一数值类型包含了处理GUID数值的方法。特别地,NewGUID方法允许你很容易地生成一个新的GUID。

 

 

Code
在WPF中,当使用Entity Framework Core (EF Core)与数据库交互时,通常情况下,`Guid` 类型在数据库中对应的是 `uniqueidentifier` 或 `binary(16)` 类型。这是因为`Guid` 是一种全局唯一标识符,数据库中的`uniqueidentifier` 列可以存储这种类型的值并保证其唯一性。 然而,具体到SQL Server,它有一个专门的`sysname` 或 `nvarchar(36)` 类型来存储`Guid`,但`binary(16)` 或 `varbinary(16)` 更常见,因为这些直接映射到了`Guid` 的二进制表示形式。在配置数据库上下文中,你可以通过`Scaffold-DbContext`命令自动生成实体映射时,EF Core会选择适当的数据库字段类型。 如果你需要在C#代码层面明确指定映射,可以在`IEntityTypeConfiguration<Article>`接口的实现中配置,如引用[5]所示: ```csharp internal class ArticleConfig : IEntityTypeConfiguration<Article> { public void Configure(EntityTypeBuilder<Article> builder) { // 如果你想在SqlServer中使用特殊的GUID列类型 if (IsSqlServer()) { builder.Property(p => p.Id).HasColumnType("uniqueidentifier"); } else { builder.Property(p => p.Id).HasColumnType("binary(16)"); } // 其他配置... } private bool IsSqlServer() { // 检查当前连接的数据库是否为SQL Server // 这里仅作示例,实际可能需要从DbContext或其他地方获取数据库信息 return string.Equals(DatabaseProvider, ProviderName.SqlServer); } } ``` 这里假设`DatabaseProvider`和`ProviderName.SqlServer`是代表数据库提供商的变量。注意,这取决于你的实际环境设置和数据库配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值