动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   数据库 → 阅读文章

 用PB生成GUID解决主键重复(2)

作者:郁郁小蝎 来源:中国站长学院 
阅读 2472 人次 , 2006-2-15 17:52:00 

  好啦,以后不用为主键重复问题再烦恼了吧。

  不过,请注意该函数需要的支持文件:(以PB7.0为例)
  pbappl.reg(执行它注册一遍,7.0以下必须此文件)
  Pbvm70.dll(不用多说了)
  Pbaen70.tlb(PB自动应用服务类库入口)

   GUID如何做到唯一?

  要确保一个标识是唯一的,仅有两个方法:
  1.通过一些机构组织来登记;
  2.使用特别的算法来产生唯一的数字,这些数字可被认为在世界范围内是唯一的。
  第一个方法很常见,比如身份证号码是国家制定的标识个人。它的问题是,制定这标识的机构组织自身存在执行偏差,而且手续繁琐,多数情况下你得花钱费时。
  第二个方法更适合于开发者。如果你可以发明一个算法,每次调用它都可以产生一个可被认为是唯一的名字,那么这个问题就解决了。

  事实上,开发软件基金会(Open Software Foundation,OSF)已经研究出一种能产生唯一标识符的算法,产生全球唯一标识符(Universally Unique Identifier,UUID)。在COM的命名标准上,微软使用同样的算法!在COM中微软将它重命名为Globally Unique Identifier(GUID)。
  生成GUID的算法根据以下几个方面:1.当前日期和时间。2.网络适配器卡地址。3.时针序。4.自动递增计数器。其中,网卡地址是相互不同的,对没有网卡的机器,地址对使用中的机器保持唯一性。
  GUID的记录通常采用16进制。不过这没有关系,一个典型的GUID类似为:"88AB240C-F761-49B8-B47F-94B0ABA4115A",略去"-",即为一个128位的唯一数字。2的128次方是一个非常大的数字。128位的接口标识符使得我们可能创建大约340282366920900000000000000000000000000个独立的接口,足够为将来10782897524560000000年每秒创建一万亿个接口。
  这是个什么概念呢?就拿这几个数字中最小的“一万亿”来说。假如把银河系缩小一万亿倍,也就是把银河系直径缩小到一百万公里,这时太阳就变成一粒芝麻,那么最大的行星木星就变成了一粒灰尘。
  即使地球毁灭了,它仍然是全球唯一。
  
 
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:用PB生成GUID解决主键重复(1)
· 下一篇:PB动态报表的实现(1)
· Microsoft SQL Server 7.0 备份及恢复相关问题
· Rman操作简单分析
· SQL2000管理SQL7服务器出现TIMEOUT问题的解决
· Access数据库技术(52)
· DB2编程序技巧 (九)


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077