您好、欢迎来到现金彩票网!
当前位置:斗牛棋牌 > 完整性约束 >

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

发布时间:2019-05-27 05:22 来源:未知 编辑:admin

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

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

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

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

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

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

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

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

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

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

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

http://dustinhetrick.com/wanzhengxingyueshu/23.html
锟斤拷锟斤拷锟斤拷QQ微锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷微锟斤拷
关于我们|联系我们|版权声明|网站地图|
Copyright © 2002-2019 现金彩票 版权所有