就是这个类的唯一标识,
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数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)