热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

数据库2—逻辑设计

概念:1、将需求转化为数据库的逻辑模型2、通过ER图的形式对逻辑模型进行展示3、同所选用的具体的DBMS系统无关名词解释:关系:一个关系对应通常所说的一张表。元组:表

概念:

1、将需求转化为数据库的逻辑模型

2、通过ER图的形式对逻辑模型进行展示

3、同所选用的具体的DBMS系统无关


名词解释:

关系:一个关系对应通常所说的一张表。

元组:表中的一行即为一个元祖。

属性:表中的一列即为一个属性;每一个属性都有一个名称,称为属性名。

候选码:表中的某个属性组,他可以唯一确定一个元祖

主码:一个关系有多个候选码,选定其中一个为主码

域:属性的取值范围

分量:元祖的一个属性值


ER图例说明:

矩形:表示实体集,矩形内写实体集的名字

菱形:表示联系集

椭圆:表示实体的属性

线段:将属性连接到实体集,或将实体集连接到联系集



设计范式概要:

用户信息和购物车信息一张表

还是用户信息一张表,购物车信息一张表


常见的数据库设计范式包括:

第一范式,第二范式,第三范式及BC范式

这也是目前我们大多数数据库设计索要遵循的范式


数据操作异常及数据冗余

插入异常:如果某实体随另一个实体的存在而存在,即缺少某个实体时无法表示这个实体,那么这个表就存在插入异常

更新异常:如果更改表所对应的某个实体实例的单独属性时,需要将多行更新,那么就说明这个表存在更新异常

删除异常:如果删除表的某一行来反映某实体实例,失效时导致另一个不同实体实例信息丢失,那么这个表中就存在删除异常

数据冗余:是指相同的数据在多个地方存在,或者说表中的某个列可以由其他列计算得到,这样就说明表中存在着数据冗余


第一范式(1NF)

定义:数据库表中所有字段都是单一属性,不可再分的。

这个单一属性是由基本的数据类型所构成的,如整数,浮点数,字符串等

换句话说,第一范式要求数据库中的表都是二维表,不是表中表


第二范式(2NF)

定义:数据库的表中不存在非关键字段对任一候选关键字的部分函数依赖

部分函数依赖是指存在着组合关键字中的某一关键字决定非关键字的情况。

换句话说:所有单关键字段的表都符合第二范式

(以下面的商品表为例来说明2NF)


是由两个关键字段来标识这一行数据的,称之为组合关键字

由于供应商和商品之间是多对多的关系

所以只有使用商品名称和供应商名称才可以唯一标识出一件商品

也就是商品名称和供应商名称是一组组合关键字

上表中存在一下的部分函数依赖

(商品名称)—>(价格,描述,重量,商品有效期)

(供应商名称)—>(供应商电话)

存在的问题:1.插入异常    2.删除异常    3.更新异常    4.数据冗余



第三范式(3NF)

定义:第三范式是在第二范式的基础之上定义的,如果数据表中不存在非关键字段,对任意候选关键字段的传递函数依赖则符合第三范式


存在以下转递函数依赖关系:

(商品名称)—>(分类)—>(分类描述)

也就是说存在非关键字段”分类描述“

对关键字段”商品名称“的传递函数依赖

存在问题:(分类,分类描述)对于每一个商品都会进行记录,所以存在着数据冗余。同时还存在着数据的插入,更新及删除异常



对第三范式的扩展,BC范式:

定义:在第三范式的基础之上,数据库表如果不存在任何字段对任一候选关键字段的传递函数依赖则符合BC范式。

也就是说如果是复合关键字,则复合关键字之间也不能存在函数依赖关系。

(以商品同供应商的关系表来说明BCNF)


假定:供应商联系人只能受雇于一家供应商,每家供应商可以供应多个商品,则存在如下决定关系:

(供应商,商品ID)—>(联系人,商品数量)

(联系人,商品ID)—>(供应商,商品数量)

存在下列关系因此不符合BCNF要求:

(供应商)—>(供应商联系人)

(供应商联系人)—>(供应商)

并且存在数据操作异常及数据冗余



总结:

1NF:列不可分就满足1NF了。

2NF:不存在部分依赖,比如(A,B)—>C。(消除非主属性对主属性的传递依赖,即完全依赖于主键)

3NF:不存在传递依赖,比如A—>B—>C。(在2NF基础上)


推荐阅读
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 三星W799在2011年的表现堪称经典,以其独特的双屏设计和强大的功能引领了双模手机的潮流。本文详细介绍其配置、功能及锁屏设置。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • Java内存管理与优化:自动与手动释放策略
    本文深入探讨了Java中的内存管理机制,包括自动垃圾回收和手动释放内存的方法。通过理解这些机制,开发者可以更好地优化程序性能并避免内存泄漏。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
author-avatar
欣仪威侑扬芸_782
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有