数据库设计的基本要求

有效数据设计的目标

一个合格的数据库应该能够满足操作:crud(create-创建,read--读取,update--更新,delete--删除)

一个合格的有效的数据库设计需要满足一下特性

  1. retrieval(检索)-------------数据如果没有办法被检索出来就不叫数据库 而叫数据黑洞

  2. 一致性:对任何相同的搜索应该提供一致的结果------指数据库的不同部分不能保存相同信息的相互矛盾的视图

       例如:如果对同一张表的同一行用相同的方式查询了两次,那么这两次的查询结果应该是严格一致的。

  3. 有效性:在可能需要的地方相对数据库中的其他数据段对数据进行验证。换句话说,就是如果你更新了一条数据,那么应该能通过查询语句来验证;如果你删除了一条数据,那么,不管怎么样查询都不会再得到你删掉的数据的内容,这就是说你的操作是有效的。

  4. 另外,轻松纠错、速度-------也是两个必要的特性,否则就有点坑爹。

  5.事务的处理需满足ACID

    ----Atomicity原子性,Consistency(一致性),Isolaion(隔离性),Durability(持久性)

    原子性---事务处理过程中的操作要么全部完成,要么什么都不执行.

    一致性---事务处理确保数据库在事务处理前后处于一致的状态。

    隔离性---是指事务处理向除了执行处理事务的人以外的所有人隐蔽其细节。

    持久性---一旦提交了一个事务处理,它的结果处理就不会消失。

  6. 当然一个数据库的存在还必须尽可能满足:低成本、可扩充性、易用性、便捷性、安全性,否则总会有新来者取而代之。

数据库的规范设计
  第一范式: 1.每个列必须要有唯一一个名称
        2.行列的次序无关紧要
        3.每一列都必须有单个的数据类型
        4.不允许包含相同值的两行----------要有主键
        5.每一列都包含一个单值
        6.列不能包含重复的数组
     说明:规则3意味着任意两行在相同的列中不允许储存不同的数据类型
        规则6表明 不能多个列包含不能区分的值

  第二范式: 1.必须符合第一范式
        2.所有的非键值字段均依赖于所有的键值字段---主键(包括联合主键)
     说明:规则2有另一种说法:部分依赖,会产生冗余数据
  第三范式: 1.符合第二范式
        2.不包含传递相关性

           从性价比的角度来说,满足前三大范式最佳。

  Boyce-Codd范式:
        1.符合第三范式;
        2.每一个决定因子都是一个候选键。
  第四范式:
        1.它是Boyce-Codd范式
        2.它不包含无关的多值依赖
  第五范式:
        1.它符合第四范式
        2.它不包含相关的多值依赖
  域/键范式
        @除了域约束和键约束,该表不包含其他约束

时间: 2024-12-21 22:46:49

数据库设计的基本要求的相关文章

Java精品高级课,架构课,java8新特性,P2P金融项目,程序设计,功能设计,数据库设计,第三方支付,web安全,视频教程

36套精品Java架构师,高并发,高性能,高可用,分布式,集群,电商,缓存,性能调优,设计模式,项目实战,P2P金融项目,大型分布式电商实战视频教程 视频课程包含: 高级Java架构师包含:Spring boot.Spring  cloud.Dubbo.Elasticsearch,Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.ZeroMQ.Git.Nosql.Jvm.Mecached.Netty.Nio.Mina.java8新特性,P2P金融项目,程序设计,

数据库设计时不得不违背三范式的情景

1.在进销存系统中,订单信息中关联到好多其他的基本信息,比如:客户,付款方式,货运方式等,这些信息是有专门表进行维护的,在下订单时也是用下拉框选择的,但在保存订单信息时,不能只记录所谓的外键ID,而是应该同时记录名称等其他的信息. 这是因为订单不能因为没有了客户ID或是付款方式ID而不知道客户与付款方式了.对于订单这种客观存在的事物,是具有一定的历史性质的,因此在设计时应该与其他的关联信息可以“断开”,这也就是保证了订单的独立性. 摘自:http://www.cnblogs.com/tongtk

从零开始编写自己的C#框架(9)——数据库设计与创建

对于千万级与百万级数据库设计是有所区别的,由于本项目是基于中小型软件开发框架来设计,记录量相对会比较少,所以数据库设计时考虑的角度是:与开发相结合:空间换性能:空间换开发效率:减少null异常......当然不同的公司与项目要求不同,初学者要学会适应不同的项目开发要求,使用本框架开发时,必须严格按照本章节的要求来设计数据库,不然可能会产生不可控的异常. 从零开始编写自己的C#框架 数据库设计规范   文件状态: [√] 草稿 [  ] 正式发布 [  ] 正在修改 文件标识: C#框架 当前版本

数据库设计的三大范式

数据库设计的三大范式 为了建立冗余较小.结构合理的数据库,设计数据库时必须遵循一定的规则.在关系型数据库中这种规则就称为范式.范式是符合某一种设计要求的总结.要想设计一个结构合理的关系型数据库,必须满足一定的范式. 在实际开发中最为常见的设计范式有三个: 1.第一范式 第一范式是最基本的范式.如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式. 第一范式的合理遵循需要根据系统的实际需求来定.比如某些数据库系统中需要用到"地址"这个属性,本来直接将"

MySql三大范式与数据库设计和表创建常用语句

[数据库设计的三大范式] 1.第一范式(1NF First Normal Fromate):数据表中的每一列(字段),必须是不可拆分的最小单元.也就是确保每一列的原子性. 例如: userInfo: '山东省烟台市 13181621008' => userAds:'山东省烟台市' tel:'13181621008' 2.第二范式(2NF):满足1NF后,要求:表中所有的列,都必须功能依赖于主键,而不能有任何一列与主键没有关系.(一张表值描述一件事情) 3.第三范式(3NF):满足2NF后,要求:

MVC实战之排球计分(一)—— 需求分析与数据库设计

一.需求分析: 这个程序是排球计分程序,其业务非常简单,具体如下: 1.本程序可以选择用户身份,通过不同角度记录比赛分数. 2.不同身份记录的比赛成绩将会存储在不同的数据表(目前适合运动员和观众使用). 3.用户键入数据后,可以继续对数据进行操作(如:删除.修改.查看详情). 4,不同的身份的用户 ,不能修改非己的数据.只能修改自己的数据. 这个项目的用例图如下: 数据库设计:设计数据表之前,首先进行实体和关系的识别与确定.通过需求分析,可以观察得出,本项目的实体有:观众,运动员.(观众可以修改

02-大鸭梨博客系统数据库设计及Dapper的使用

毫无疑问,数据库的设计在一个系统中起了至关重要的作用.我们都知道,系统设计分为两部分,或者说是两个阶段,即数据库设计和功能设计.构建一个完善的系统需要这两个阶段的充分考量.周密设计.合理联接以及密切配合.数据库设计是整个系统的根基,它关乎系统功能的实现.稳定性.扩展性等多个方面,可见数据库设计的重要性. 那么好的数据库设计应该具备什么样的基本条件呢,大致有这么几点: 1.充分体现系统的需求 不管是数据库设计还是功能设计,我们最终的目的都是要实现客户的业务需求,所以数据库设计的第一准则就是要符合业

学生信息管理系统1(数据库设计篇)

1.系统概述 本次是做一个学生管理系统,在学了数据库之后,希望通过这个系统把所学知识应用与实际项目中去.加强自己的熟练程度. 开发背景:具备数据库,C#的相关知识储备,掌握基本的html知识. 用途:仅作练习用.通过一门语言,将数据库展现出来. 2.功能需求分析 系统概念层设计:功能用例图如下 1. 登录功能:用于身份认证 2. 数据操作:信息查询,数据的增删改.a) 数据操作里,管理员具备所有的操作权限.学生具有选课和查看的功能.以及可以修改自己的个人信息.3. UI设计 3.数据库设计 E-

数据库设计【笔记】

数据库设计 一.设计步骤   1.收集信息(来源项目需求分析)   2.标识实体(一般是需求分析中需要管理的信息名词)   3.标识每个实体的属性   4.实体之间的关系二.画e-r图(实体关系图)   1.矩形表示实体   2.椭圆表示实体的属性   3.菱形表示实体之间的关系   4.用直线连接实体和属性,实体和实体之间的关系三.实体之间的关系:   1.一对一  1:1          车和车位   2.一对多  1:N (1:M) 客人和客房   3.多对多  N:M         

数据库设计系列之二

首先来了解下数据库设计是什么? 通俗的讲就是,根据业务系统的具体需要,结合我们所选用的DBMS(数据库管理系统),为这个业务系统构造出最优的数据存储模型.并建立好数据库中的表结构及表与表之间的关联关系的过程.使之能有效的对应用系统中的数据进行存储,并可以高效的对已经存储的数据进行访问. 接下来是为什么要进行数据库设计? 数据库设计的一些步骤: 一.需求分析: 数据库需求的作用点: 1.数据是是什么? 2.数据有哪些属性? 3.数据和属性各自的特点有哪些? 二.逻辑设计: 使用ER图对数据库进行逻