加强客户端约束增强数据库完整性

时间:2018-10-19 23:30来源:未知 作者:admin 围观:字体://

  数据库的完整性是影响客户/服务器应用系统正常运行的重要因素。维护数据库的完整性不仅是数据库设计人员的任务,也需要客户端开发人员的积极参与。不在客户端进行完整性约束,一般会引起ODBC错误,导致数据库操作失败,程序异常中断。更为严重的是在某些情况下会突破服务器的约束机制,bt365体育投注网破坏后台数据库的完整性。因此,正规的体育投注站只有双方相互配合才能开发出完整、可靠的客户/服务器系统。下面以MSSQLServer6.5和VB5.0为例,对客户端应用开发中的数据库完整性问题进行讨论。其原理同样适用于其他开发环境。

  参照(引用)完整性(ReferenceIntegrity),在一个数据库的多个表中保持一致性。

  UNIQUE为指定该列不能有重复值,体育投注站。但可对定义为关键字以外的任何列使用;

  PRIMARYKEY为对表指定主关键字。用来保证列的完整性和引用完整性。它的主要作用:

  2.保证受约束的列不允许为空值。正规的体育投注站从这个角度来讲,相当于NOTNULL和UNIQUE。

  FOREIGNKEY为指定外来关键字。与定义在相关表上的PRIMARYKEY一起使用。

  MSSQLServer6.5还提供了数据完整性扩展,bt365体育投注网如用户自定义类型、规则、存储过程和触发器。SQLServer6.5对不同完整性的约束方法见下表。

  检查受UNIQUE约束的字段不能有重复值输入。如对顺序编号等字段采用自动增量的方式,或者在接受输入前检查数据库。对布尔型字段,使用Check控件供用户输入,以限制非法数据。对有限的枚举列字段,使用ListBox或ComboBox控件,列出全部有效值供用户挑选。对外来关键字字段,使用ListBox或ComboBox控件,动态列出全部有效值供用户挑选。如在一个设备管理数据库中,企业信息表FacMsg中的企业名称字段是设备Devices中企业名称字段的外来关键字。当成功地添加了一个新企业记录后,要将新企业的名称添加到FrmDevices的FacName列表控件中。

  同样,当成功地删除了一个企业记录后,要将该企业的名称从FrmDevices的FacName列表控件中删除。

  充分考虑扩展的约束,如自定义类型、规则、存储过程和触发器,以免造成冲突。

  实践表明,采用以上方法可以有效避免用户(尤其是对系统不熟悉的用户)的非法输入,同时弥补《计算机世界》1998年第36期用VB5RDO访问数据库出现的缺陷及改正一文所指出的数据库缺陷。

  * 网友发言均非本站立场,本站不在评论栏推荐任何网店、经销商,谨防上当受骗!

  更多

  iPhoneXR正式开卖,理性分析花6000元该买苹果还是华为Mate20?

  微软悄然提高Windows 10售价,家庭版涨至1088元!你升级了吗?

  今日特价 松下gh5今日最新报价5200元,全新正品国行,三码合一可检测

相关标签:数据库完整性(11)
相关文章:
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:

Baidu