热门标签 | 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基础上)


推荐阅读
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 阿里Treebased Deep Match(TDM) 学习笔记及技术发展回顾
    本文介绍了阿里Treebased Deep Match(TDM)的学习笔记,同时回顾了工业界技术发展的几代演进。从基于统计的启发式规则方法到基于内积模型的向量检索方法,再到引入复杂深度学习模型的下一代匹配技术。文章详细解释了基于统计的启发式规则方法和基于内积模型的向量检索方法的原理和应用,并介绍了TDM的背景和优势。最后,文章提到了向量距离和基于向量聚类的索引结构对于加速匹配效率的作用。本文对于理解TDM的学习过程和了解匹配技术的发展具有重要意义。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • Final关键字的含义及用法详解
    本文详细介绍了Java中final关键字的含义和用法。final关键字可以修饰非抽象类、非抽象类成员方法和变量。final类不能被继承,final类中的方法默认是final的。final方法不能被子类的方法覆盖,但可以被继承。final成员变量表示常量,只能被赋值一次,赋值后值不再改变。文章还讨论了final类和final方法的应用场景,以及使用final方法的两个原因:锁定方法防止修改和提高执行效率。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • 【Windows】实现微信双开或多开的方法及步骤详解
    本文介绍了在Windows系统下实现微信双开或多开的方法,通过安装微信电脑版、复制微信程序启动路径、修改文本文件为bat文件等步骤,实现同时登录两个或多个微信的效果。相比于使用虚拟机的方法,本方法更简单易行,适用于任何电脑,并且不会消耗过多系统资源。详细步骤和原理解释请参考本文内容。 ... [详细]
  • JavaScript设计模式之策略模式(Strategy Pattern)的优势及应用
    本文介绍了JavaScript设计模式之策略模式(Strategy Pattern)的定义和优势,策略模式可以避免代码中的多重判断条件,体现了开放-封闭原则。同时,策略模式的应用可以使系统的算法重复利用,避免复制粘贴。然而,策略模式也会增加策略类的数量,违反最少知识原则,需要了解各种策略类才能更好地应用于业务中。本文还以员工年终奖的计算为例,说明了策略模式的应用场景和实现方式。 ... [详细]
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社区 版权所有