`
haitan
  • 浏览: 36615 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

数据库设计经验谈:第4 部分— 保证数据的完整性

阅读更多

1. 用约束而非商务规则强制数据完整性
  如果你按照商务规则来处理需求,那么你应当检查商务层次/用户界面:如果商务规则以后发生变化,那么只需要进行更新即可。
  假如需求源于维护数据完整性的需要,那么在数据库层面上需要施加限制条件。
  如果你在数据层确实采用了约束,你要保证有办法把更新不能通过约束检查的原因采用用户理解
  的语言通知用户界面。除非你 的字段命名很冗长,否则字段名本身还不够。
  — Lamont Adams
  只要有可能,请采用数据库系统实现数据的完整性。这不但包括通过标准化实现的完整性而且还包括数据的功能性。在写数据的时候还可以增加触发器来保证数据的正确性。不要依赖于商务层保证数据完整性;它不能保证表之间(外键)的完整性所以不能强加于其他完整性规则之上。
  — Peter Ritchie
  2. 分布式数据系统
  对分布式系统而言,在你决定是否在各个站点复制所有数据还是把数据保存在一个地方之前应该估计一下未来5 年或者10 年的数据量。当你把数据传送到其他站点的时候,最好在数据库字段中设置一些标记。在目的站点收到你的数据之后更新你的标记。为了进行这种数据传输,请写下你自己的批处理或者调度程序以特定时间间隔运行而不要让用户在每天的工作后传输数据。本地拷贝你的维护数据,比如计算常数和利息率等,设置版本号保证数据在每个站点都完全一致。
  — Suhair TechRepublic
  3. 强制指示完整性
  没有好办法能在有害数据进入数据库之后消除它,所以你应该在它进入数据库之前将其剔除。激活数据库系统的指示完整性特性。这样可以保持数据的清洁而能迫使开发人员投入更多的时间处理错误条件。
  — kol
  4. 关系
  如果两个实体之间存在多对一关系,而且还有可能转化为多对多关系,那么你最好一开始就设置成多对多关系。从现有的多对一关系转变为多对多关系比一开始就是多对多关系要难得多。
  — CS Data Architect
  5. 采用视图
  为了在你的数据库和你的应用程序代码之间提供另一层抽象,你可以为你的应用程序建立专门的视图而不必非要应用程序直接访问数据表。这样做还等于在处理数据库变更时给你提供了更多的自由。
  — Gay Howe
  6. 给数据保有和恢复制定计划
  考虑数据保有策略并包含在设计过程中,预先设计你的数据恢复过程。采用可以发布给用户/开发人员的数据字典实现方便的数据识别同时保证对数据源文档化。编写在线更新来“更新查询”供以后万一数据丢失可以重新处理更新。
  — kol
  7. 用存储过程让系统做重活
  解决了许多麻烦来产生一个具有高度完整性的数据库解决方案之后,我所在的团队决定封装一些关联表的功能组,提供一整套常规的存储过程来访问各组以便加快速度和简化客户程序代码的开发。在此期间,我们发现3GL 编码器设置了所有可能的错误条件,比如以下所示:
  SELECT Cnt = COUNT (*)
  FROM [<Table>]
  WHERE [<primary key column>] = <new value>
  IF Cnt = 0
  BEGIN
  INSERT INTO [<Table>]
  ( [< primary key column>] )
  VALUES ( <New value> )
  END
  ELSE
  BEGIN
  <indicate duplication error>
  END
  而一个非3GL 编码器是这样做的:
  INSERT INTO [<Table>]
  ( [< primary key column>] )
  VALUES
  ( <New value> )
  IF @@ERROR = 2627 -- Literal error code for Primary Key Constraint
  BEGIN
  <indicate duplication error>
  END
  第2 个程序简单多了,而且事实上,利用了我们给数据库的功能。虽然我个人不喜欢使用嵌入文字(2627)。但是那样可以很方便地用一点预先处理来代替。数据库不只是一个存放数据的地方,它也是简化编码之地。
  — a-smith
  8. 使用查找
  控制数据完整性的最佳方式就是限制用户的选择。只要有可能都应该提供给用户一个清晰的价值列表供其选择。这样将减少键入代码的错误和误解同时提供数据的一致性。某些公共数据特别适合查找:国家代码、状态代码等。
  — CS Data Architect

分享到:
评论

相关推荐

    数据库设计经验谈.pdf

    #### 第四部分:保证数据完整性 **1. 实体完整性** - **主键约束**:确保每张表都有唯一的主键。 - **外键约束**:建立表之间的关系,维护数据一致性。 **2. 参照完整性** - **级联更新/删除**:当更新或删除父...

    数据库设计之——数据库设计经验谈

    ### 数据库设计之——数据库设计经验谈 在当今数字化时代,数据成为了企业运营的重要组成部分,而数据库则是管理和存储这些数据的核心工具。一个优秀的数据库设计能够极大地提升系统的性能、可靠性和可扩展性。本文...

    数据库设计经验谈.doc

    **第 4 部分 - 保证数据完整性** 数据完整性是数据库设计的核心。实体完整性要求主键字段不能为NULL;参照完整性确保了引用关系的正确性;用户定义的完整性则是针对特定业务规则的约束。通过设置适当的约束(如NOT ...

    关于数据库设计的经验谈

    #### 第4部分-保证数据完整性 这部分将探讨如何通过约束、触发器等机制来维持数据库的完整性和一致性,确保数据质量并降低潜在风险。 #### 第5部分-各种小技巧 这部分包含了一些实用的小技巧,可以帮助开发者更...

    浅谈数据库设计技巧经验

    2. **系统学习过数据结构但缺乏实战经验的程序员**:这类程序员倾向于严格按照教科书上的规范设计数据库,如E-R图和第三范式(3NF)等。虽然能满足一般需求,但随着应用的发展,可能会面临较大的调整压力。 3. **...

    浅谈数据库设计技巧-程序员应该读的

    2. 外键应用:用于连接不同表,实现数据关联,确保数据完整性。 3. 字段类型选择:根据数据特性选择合适的数据类型,如INT、VARCHAR、DATE等。 4. 索引设计:合理设置索引可以显著提升查询速度,但过多的索引会影响...

    赢在起点-数据库设计规范 梁敬彬大牛的经验之谈

    4. 规范化理论:数据库设计应遵循第一范式(1NF)、第二范式(2NF)、第三范式(3NF),以及更高的BCNF和4NF,以减少数据冗余和提高数据一致性。 5. 主键与外键:主键用于唯一标识表中每一行,应选择不为空且唯一的...

    课程设计之高校二手平台数据库设计.docx

    - **交互信息**:常见问题、完全攻略、实战经验谈。 - **信息发布** - **商品信息**:按照类别分类,如电脑网络、交通工具、家用电器等。 - **热点信息**:当前热门的商品或话题。 - **信息查看**:站内搜索和...

    powerbuilder编程经验谈.

    - **事务处理**:PB支持事务管理,确保数据的一致性和完整性。 - **存储过程与函数**:PB可以直接调用数据库中的存储过程和函数,提高应用性能。 3. **事件驱动编程** - **事件响应**:PB的控件和窗口都有预定义...

    高可用分布式架构设计与实践-内训方案.pdf

    为了保证数据的高可用性和持久性,通常会在不同节点之间进行数据复制,实现数据冗余。 - **数据备份如何落地** 数据备份是一项重要的运维工作,包括定期备份、增量备份等多种策略。合理的备份计划可以帮助企业在...

    国内外主流的三维GIS软件

     介绍:数据地球(中国)(Data Earth China)是我国第一个集数据与软件一体化的三维地理空间信息系统,它在国家863计划地球观测与导航技术领域项目支持下,由中国资源卫星应用中心、视宝公司和北京星天地公司三家...

    超级商务谈判技巧讲义.pptx

    - **关键点**:深入了解对手,将谈判诉求转化为完整利益链,明确对方的需求点。 - **价格数据库**:整理过往交易的价格信息,为定价提供依据。 - **个人资料**(声誉特点):了解谈判对手的性格特点、偏好等,...

Global site tag (gtag.js) - Google Analytics