在C#中,请问 typeof(XXX).guid代表什么意思呢初学C#,实在是不清楚,请高手指点一下

在C#中,请问 typeof(XXX).guid代表什么意思呢初学C#,实在是不清楚,请高手指点一下,第1张

就是这个类的唯一标识,

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 世界上任何两台计算机都不会生成重复的 GUID 值。GUID 主要用于在拥有多个节点、多台计算机的网络或系统中,分配必须具有唯一性的标识符。

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

NET中使用GUID

当Windows开发人员需要一个唯一数值时,他们通常使用到一个全局唯一标识符(GUID, Globally Unique Identifier)。微软采用GUID术语来表示这一唯一数值,而这一数值能够标识一个实体,比如一个Word文档。

一个GUID为一个128位的整数(16字节),在使用唯一标识符的情况下,你可以在所有计算机和网络之间使用这一整数。

这一篇文章将解释NET框架如何尽其最大潜力地为你建立自己的GUID。

你所看到的

GUIDs被用于整个Windows环境。当你在一个Windows系统中仔细阅读注册表时,你可以看到GUIDs被广泛用于唯一识别程序。特别地,它们作为程序的Ids集中在HKEY_CLASSES_ROOT部分(AppID键)。

这就是一个典型的GUID的格式:

936DA01F-9ABD-4d9d-80C7-02AF85C822A8

在NET中生成一个GUID

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

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

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

以下的C#命令行程序说明这一使用过程:

using System;

namespace DisplayGUID {

class GuidExample {

static void Main(string[] args) {

ConsoleWriteLine("GUID: " + SystemGuidNewGuid()ToString());

}

} }

下面为这一程序的输出:(虽然不同系统之间的GUID是变化的。)

GUID: 9245fe4a-d402-451c-b9ed-9c1a04247482

在这一点上,你可以看到GUID是一个很好的功能,但在程序的什么地方使用到它们,并如何使用它们?

在程序中使用一个GUID

一个GUID可以在后台数据库中 *** 作一个主键。以下代码使用一个GUID在一个后台数据库中存储信息,这一数据库包含以下的列:

pk_guid—uniqueidentifier数据类型

name—nvarchar数据类型

这样出现一个包含文本框的简单Windows窗体。当选择按钮时,文本框中的数据被插入到数据库中。通过程序代码可以生成一个GUID并存储在其它列中:

StringBuilder strSql = new StringBuilder();

strSqlAppend("Insert into cs_Content(");

strSqlAppend("Log_guid, Log_Title, Log_Content, Log_PostTime, Log_ViewNums)");

strSqlAppend(" values (");

strSqlAppend("@Log_guid, @Log_Title, @Log_Content, @Log_PostTime, @Log_ViewNums)");

DbCommand dbCommand = dbGetSqlStringCommand(strSqlToString());

string guid = GuidNewGuid()ToString();

// Add parameters

dbAddInParameter(dbCommand, "Log_guid", DbTypeString, guid);

dbAddInParameter(dbCommand, "Log_Title", DbTypeString, modelLog_Title);

dbAddInParameter(dbCommand, "Log_Content", DbTypeString, modelLog_Content);

dbAddInParameter(dbCommand, "Log_PostTime", DbTypeDateTime, modelLog_PostTime);

dbAddInParameter(dbCommand, "Log_ViewNums", DbTypeInt32, modelLog_ViewNums);

int res = dbExecuteNonQuery(dbCommand);

另一个GUID程序将一个唯一的标识符分配给一个NET类或者接口,也就是说,GUID作为一个属性被分配给类或者接口。可以使用标准属性语法来实现这一过程

我们可以扩展第一个范例来分配一个GUID。SystemRuntimeInteropServices空间名称必须被引用来使用GUID属性。以下C#代码实现了这一过程:

using SystemReflection;

using SystemRuntimeCompilerServices;

using SystemRuntimeInteropServices;

// 有关程序集的常规信息通过下列属性集

// 控制。更改这些属性值可修改

// 与程序集关联的信息。

[assembly: AssemblyTitle("Test")]

// 将 ComVisible 设置为 false 使此程序集中的类型

// 对 COM 组件不可见。如果需要从 COM 访问此程序集中的类型,

// 则将该类型上的 ComVisible 属性设置为 true。

[assembly: ComVisible(false)]

// 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID

[assembly: Guid("198cfad8-041f-4141-8961-776b29af7a06")]

// 程序集的版本信息由下面四个值组成:

//

// 主版本

// 次版本

// 内部版本号

// 修订号

//

// 可以指定所有这些值,也可以使用“内部版本号”和“修订号”的默认值,

// 方法是按如下所示使用“”:

// [assembly: AssemblyVersion("10")]

[assembly: AssemblyVersion("1000")]

[assembly: AssemblyFileVersion("1000")]

GUID永远是方便的

对于程序开发的各个方面,NET Framework简化了建立和处理GUID数值的过程。在NET程序需要的地方,这一功能很容易地生成唯一的数值。

------------

1、GuidNewGuid()ToString("N") 结果为:

38bddf48f43c48588e0d78761eaa1ce6

2、GuidNewGuid()ToString("D") 结果为:

57d99d89-caab-482a-a0e9-a0a803eed3ba

3、GuidNewGuid()ToString("B") 结果为:

{09f140d5-af72-44ba-a763-c861304b46f8}

4、GuidNewGuid()ToString("P") 结果为:

(778406c2-efff-4262-ab03-70a77d09c2b5)

可见默认的为第2种效果

将字符串形式的GUID:EF41A66B-25E1-46B2-964B-E4F70534807F转换为SystemGuid类型

SystemGuid mGuid=new Guid("EF41A66B-25E1-46B2-964B-E4F70534807F");

-----------------

guid的每段位数:8+4+4+4+12

-------------------

GUID重复的可能性几乎为0,可放心使用,重复的机率比碰鬼的机率还小,在不同的机器上如此,在同一台机器上重复的机率更是几乎不可能

使用C#GuidNewGuid()生成的GUID长度为36位

GUID(Global unique identifier)全局唯一标识符 它是由网卡上的标识数字(每个网卡都有唯一的标识号)以及 CPU 时钟的唯一数字生成的的一个 字节的二进制值

GUID 的格式为 xxxxxxxx xxxx xxxx xxxx xxxxxxxxxxxx 其中每个 x 是 或 a f 范围内的一个十六进制的数字 例如 F FF B D B D C FC FF 即为有效的 GUID 值

世界上的任何两台计算机都不会生成重复的 GUID 值 GUID 主要用于在拥有多个节点 多台计算机的网络或系统中 分配必须具有唯一性的标识符 在 Windows 平台上 GUID 应用非常广泛 注册表 类及接口标识 数据库 甚至自动生成的机器名 目录名等

在这次开发 ASP NET 应用时 我大量使用了类型为 GUID 的 ID 列作为各实体表的关键字(键) 由于其唯一 易产生的特性 给应用程序处理带来诸多好处

在 SQL Server 中使用 GUID

如果在 SQL Server 的表定义中将列类型指定为 uniqueidentifier 则列的值就为 GUID 类型

SQL Server 中的 NewID() 函数可以产生 GUID 唯一值 使用此函数的几种方式如下

) 作为列默认值

将 uniqueidentifier 的列的默认值设为 NewID() 这样当新行插入表中时 会自动生成此列 GUID 值

)使用 T SQL

在 T SQL 中使用 NewID()函数 如 INSERT INTO Table(ID ) VALUES(NewID() ) 来生成此列的 GUID 值

)提前获取 GUID 值

由于特殊功能需要 需要预先获知新行的 ID 值 也可以使用如下 C# 代码提前获得 GUID 的值 再存储到数据库中:

SqlCommand cmd = New SqlCommand();

cmd CommandText = SELECT NewID() ;

string rowID = (string) cmd ExecuteScalar();

cmd CommandText = INSERT INTO Table(ID ) VALUES(@ID )

cmd Parameters Add( @ID SqlDbType UniqueIdentifier) Value = new Guid(rowID);

cmd ExecuteNoQuery();

uniqueidentifier 值不能进行算术运算 但可以进行(意义不大的)比较 *** 作和 NULL 检查 它不能象 IDENTITY 列一样 可以获知每行的增加时间的先后顺序 只能通过增加其它时间或时间戳列来完成此功能

>>PS:Oracle获取guid的方式为sys_guid()

在 NET 中使用 GUID

GUID 在 NET 中使用非常广泛 而且 NET Framework 提供了专门 Guid 基础结构

Guid 结构的常用法包括

) Guid NewGUID()

生成一个新的 GUID 唯一值

) Guid ToString()

将 GUID 值转换成字符串 便于处理

)构造函数 Guid(string)

由 string 生成 Guid 结构 其中string 可以为大写 也可以为小写 可以包含两端的定界符 {} 或 () 甚至可以省略中间的 Guid 结构的构造函数有很多 其它构造用法并不常用

同时 为了适用数据库中使用 GUID 的需要 NET Framework 也提供了 SqlGUID 结构 它和 Guid 结构类似 只是两者对排序(CompareTo)的处理方式不同 SqlGuid 计算值的最后 个字节 而 Guid 计算全部 个字节 这种差异可能会给 SQL Server 中 uniqueidentifier 列的排序带来一定影响 当然这种排序意义也不大

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

GUID 的优缺点

) 优点

同 IDENTITY 列相比 uniqueidentifier 列可以通过 NewID() 函数提前得知新增加的行 ID 为应用程序的后续处理提供了很大方便

便于数据库移植 其它数据库中并不一定具有 IDENTITY 列 而 Guid 列可以作为字符型列转换到其它数据库中 同时将应用程序中产生的 GUID 值存入数据库 它不会对原有数据带来影响

便于数据库初始化 如果应用程序要加载一些初始数据 IDENTITY 列的处理方式就比较麻烦 而 uniqueidentifier 列则无需任何处理 直接用 T SQL 加载即可

便于对某些对象或常量进行永久标识 如类的 ClassID 对象的实例标识 UDDI 中的联系人 服务接口 tModel标识定义等

) 缺点

GUID 值较长 不容易记忆和输入 而且这个值是随机 无顺序的 所以使用时要注意场合 最好不要尝试用它来作为你的电子邮件地址 J

GUID 的值有 个字节 与其它那些诸如 字节的整数相比要相对大一些 这意味着如果在数据库中使用 uniqueidentifier 键 可能会带来两方面的消极影响 存储空间增大 索引时间较慢

lishixinzhi/Article/program/net/201311/13985

你什么数据库啊?

把你建表语句发来看看

sqlserver

insert into 表名 (字段名) values (newid())

oracle

insert into 表名(字段名) values (sys_guid())

mysql

insert into 表名(字段名) values(UUID())

你按你是什么数据库挑着用吧

在很多情况下我们需要将指定的数据库中的所有表都列出来 在使用c#进行软件开发时 我们有哪些方法可是实现这个目的呢?本人对此进行概要的总结 有以下 中方式可以实现这个目的

1 sqldmo

SQLDMO是 *** 作SQLServer的理想的方式 如果您的数据库是SQLServer就可以考虑使用这种方式 在C#中使用SQLDMO需要添加SQLDMO的引用 然后在当前的文件中using SQLDMO;即可以使用SQLDMO SQLDMO的对象模型大家可以在SQLServer的帮助中获得

private void GetTabels_DMO(string strServerName string strUser string strPWD string strDatabase)

{

SQLDMO SQLServer Server = new SQLDMO SQLServerClass();

//连接到服务器

Server Connect(strServerName strUser strPWD);

//对所有的数据库遍历 获得指定数据库

for(int i= ;i<Server Databases Count;i++)

{

//判断当前数据库是否是指定数据库

if(Server Databases Item(i+ dbo ) Name ==strDatabase)

{

//获得指定数据库

SQLDMO _Database db= Server Databases Item(i+ dbo );

//获得指定数据库中的所有表

for(int j= ;j<db Tables Count;j++)

{

MessageBox Show(db Tables Item(j+ dbo ) Name);

}

}

}

}

2 adox

adox是ado Extensions for DDL and Security 是微软对ADO技术的扩展 使用它我们可以 *** 作数据库的结构 它是一个组件 估计以后在ADO NET中会增加ADOX的一些功能 如果大家需要ADOX的一些资料 我可以提供 下面的一个例子就是使用ADOX来获得当前数据库的所有表

private void GetTables_ADOX()

{

//ADO的数据库连接

ADODB ConnectionClass cn=new ADODB ConnectionClass();

string ConnectionString= Provider=SQLOLEDB ;Integrated Security=SSPI;Initial Catalog=Test;Data Source=HBXP ;

cn Open(ConnectionString sa );

// *** 作ADOX的Catalog对象

CatalogClass cat=new CatalogClass();

cat ActiveConnection=cn;

for(int i= ;i<cat Tables Count;i++)

{

MessageBox Show(cat Tables[i] Name);

}

}

注意 在上面的代码中cat ActiveConnection不能是ADO Net中的Connection 而应该是ADO的Connection

3 中的oledbconnection

在c#中我们首先会考虑使用来解决问题 如果没有方法才会考虑使用adox或者sqldmo来解决这个问题 虽然adox和sqldmo也能够解决这个问题 但是他们毕竟是组件 中使用起来和在平台会有一些差异 不是很顺手 下面的示例就显示了在中的oledbconnection的方法getoledbschematable来获得数据库的架构 大家可以在msdn中看到这个方法的说明

public DataTable GetOleDbSchemaTable(

Guid schema

object[] restrictions);

参数

schema

OleDbSchemaGuid 的值之一 它指定要返回的架构表

restrictions

限制值的 Object 数组 这些值按照限制列的顺序来应用 即 第一个限制值应用于第一个限制列 第二个限制值应用于第二个限制列 依此类推

返回值

包含请求的架构信息的 DataTable

更多的信息大家可以查询MSDN 下面将示例如何实现

private void GetTables_ADONET()

{

//处理OleDbConnection

string mailto:strConnectionString=@% Integrated Security=SSPI;Data Source=HBXP;Initial Catalog=Test;Provider=SQLOLEDB ;

OleDbConnection cn=new OleDbConnection(strConnectionString);

cn Open();

//利用OleDbConnection的GetOleDbSchemaTable来获得数据库的结构

DataTable dt = cn GetOleDbSchemaTable(OleDbSchemaGuid Tables new object[] {null null null TABLE });

foreach (DataRow dr in  dt Rows)

{

MessageBox Show((String)dr[ TABLE_NAME ]);

}

}

4 信息架构视图

信息架构视图是sql 标准中定义的架构视图 这些视图独立于系统表 信息架构视图的最大优点是 即使我们对系统表进行了重要的修改 应用程序也可以正常地使用这些视图进行访问 下面的示例使用信息架构视图来工作

private void GetTables_INFORMATION_SCHEMA()

{

//打开连接

string strConnectionString=System Configuration ConfigurationSettings AppSettings[ ConnectionString ];

sqlcn=new SqlConnection(strConnectionString);

sqlcn Open();

//使用信息架构视图

SqlCommand sqlcmd=new SqlCommand( SELECT TABLE_NAME FROM INFORMATION_SCHEMA TABLES WHERE TABLE_TYPE = BASE TABLE sqlcn);

SqlDataReader dr=sqlcmd ExecuteReader();

while(dr Read())

{

MessageBox Show(dr GetString( ));

}

}

5 使用系统表

如果您的数据库系统是sqlserver 就可以使用如下的方式来获得当前数据库的所有表

private void GetTables_SystemTable()

{

//打开连接

string strConnectionString=System Configuration ConfigurationSettings AppSettings[ ConnectionString ];

sqlcn=new SqlConnection(strConnectionString);

sqlcn Open();

//使用信息架构视图

SqlCommand sqlcmd=new SqlCommand( SELECT OBJECT_NAME (id) FROM sysobjects WHERE xtype = U AND OBJECTPROPERTY (id IsMSShipped ) = sqlcn);

SqlDataReader dr=sqlcmd ExecuteReader();

while(dr Read())

{

MessageBox Show(dr GetString( ));

}

}

使用sqlserver的存储过程 sp_tables

下面是 盛国军 朋友提出的使用存储过程的方法的补充代码

public void GetTables_StoredProcedure()

{

//处理OleDbConnection

string mailto:strConnectionString=@% Integrated Security=SSPI;Data Source=HBXP;Initial Catalog=Test;Provider=SQLOLEDB ;

OleDbConnection cn=new OleDbConnection(strConnectionString);

cn Open();

//执行存储过程

OleDbCommand cmd=new OleDbCommand( sp_tables cn);

cmd CommandType=CommandType StoredProcedure;

OleDbDataReader dr=cmd ExecuteReader();

while(dr Read())

{

MessageBox Show(dr[ TABLE_NAME ] ToString());

}

lishixinzhi/Article/program/net/201311/13176

如果主键是Guid,数据库给主键列以newid()的默认值,EF也会将主键值返回并更新模型的对应属性的,前提是要在EF中Mapping类中要设置

thisProperty(t => tTipID)HasDatabaseGeneratedOptio(DatabaseGeneratedOptionIdentity);

此时生成的SQL语句和自增长的有所不同

exec sp_executesql N'declare @generated_keys table([TipID] uniqueidentifier)

insert [dbo][Tips]([Description])

output inserted[TipID] into @generated_keys

values (@0)

select t[TipID]

from @generated_keys as g join [dbo][Tips] as t on g[TipID] = t[TipID]

where @@ROWCOUNT > 0',N'@0 nvarchar(max) ',@0=N'testing'

注意:这里定义了一个表变量@generated_keys,插入的时候将id输出给@generated_keys表的字段,

这里values (@0)是针对insert [dbo][Tips]([Description]) 而言的,先执行insert

再执行output inserted[TipID] into @generated_keys 将插入的id输出到@generated_keys 中

EF真的是太强大了,可以模仿EF生成SQL语句,这极大地提升本人写SQL的水平,Entity Framework生成的SQL是很有水平的!

这样就可以返回刚新插入的主键值!

以上就是关于在C#中,请问 typeof(XXX).guid代表什么意思呢初学C#,实在是不清楚,请高手指点一下全部的内容,包括:在C#中,请问 typeof(XXX).guid代表什么意思呢初学C#,实在是不清楚,请高手指点一下、ASP.NET中GUID、SQL 表已经建立好了 如何在字段中插入GUID数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9746054.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存