成都哪里可以做网站,成都建设诚信网站,wordpress tdk优化,用源代码做网站1、数据库范式的作用数据库范式主要是为解决关系数据库中数据冗余、更新异常、插入异常、删除异常问题而引入的设计理念。简单来说#xff0c;数据库范式可以避免数据冗余#xff0c;减少数据库的存储空间#xff0c;并且减轻维护数据完整性的成本。是关系数据库核心的技术之… 1、数据库范式的作用数据库范式主要是为解决关系数据库中数据冗余、更新异常、插入异常、删除异常问题而引入的设计理念。简单来说数据库范式可以避免数据冗余减少数据库的存储空间并且减轻维护数据完整性的成本。是关系数据库核心的技术之一也是从事数据库开发人员必备知识。2、数据库范式分类介绍范式是评价数据库模式规范化程度从低到高主要有1NF、2NF、3Nf、BCNF、4NF、5NF。2.1 1NF 第一范式强调属性的原子性约束要求属性具有原子性不可再分解。举例学生表(学号、姓名、年龄、性别、地址)。地址可以细分为国家、省份、城市、市区、街道那么该模式就没有达到第一范式。第一范式存在问题冗余度大、会引起修改操作的不一致性、数据插入异常、数据删除异常。2.2 2NF 第二范式第二范式强调记录的唯一性约束数据表必须有一个主键并且没有包含在主键中的列必须完全依赖于主键而不能只依赖于主键的一部分。举例版本表版本编码版本名称产品编码产品名称其中主键是版本编码产品编码这个场景中数据库设计并不符合第二范式因为产品名称只依赖于产品编码。存在部分依赖。所以为了使其满足第二范式可以改造成两个表版本表版本编码产品编码和产品表产品编码产品名称2.3 3NF 第三范式第三范式强调数据属性冗余性的约束也就是非主键列必须直接依赖于主键。也就是消除了非主属性对码的传递函数依赖。举例订单表订单编码顾客编码顾客名称其中主键是订单编码这个场景中顾客编码、顾客名称都完全依赖于主键因此符合第二范式但顾客名称依赖于顾客编码从而间接依赖于主键所以不能满足第三范式。如果要满足第三范式需要拆分为两个表订单表订单编码顾客编码和顾客表顾客编码顾客名称。说明3NF的模式肯定满足2NF。产生冗余和异常的两个重要原因是部分依赖和传递依赖。3NF模式中不存在非主属性对码的部分函数依赖和传递函数依赖性能较好。1NF、2NF一般不适合作为数据库模式通常需要转换为3NF或者更高级别的范式这种变换过程称为关系模式规范化处理。2.4 BCNFBovce Codd Normal Form 巴克斯范式属于修正的第三范式是防止主键的某一列会依赖于主键的其他列。当3NF消除了主属性对码的部分函数依赖和传递函数依赖称为BCNF。特性1、所有主属性对每一个码都是完全函数依赖2、所有主属性对每一个不包含它的码也是完全函数依赖3、没有任何属性完全函数依赖与非码的任何一组属性举例库存表仓库名管理员名商品名数量主键为仓库名管理员名商品名这是满足前面三个范式的但是仓库名和管理员名之间存在依赖关系因此删除某一个仓库会导致管理员也被删除这样就不满足BCNF。2.5 4NF 第四范式 非主属性不应该有多值。如果有多值就违反了第四范式。4NF是限制关系模式的属性间不允许有非平凡且非函数依赖的多值依赖。举例用户联系方式表用户id固定电话移动电话其中用户id是主键这个满足了BCNF,但是一个用户有可能会有多个固定电话或者多个移动电话那么这种设计就不合理应该改为用户id联系方式类型电话号码。说明如果只考虑函数依赖关系模式规范化程度最高的范式是BCNF如果考虑多值依赖则是4NF。2.6 5NF 第五范式第五范式属于最终范式消除了4NF中的连接依赖第五范式需要满足以下要求1、必须满足第四范式2、表必须可以分解为较小的表除非那些表在逻辑上拥有与原始表相同的主键。一般实际应用中不必考虑第五范式。IT技术分享社区个人博客网站https://programmerblog.xyz文章推荐程序员效率画流程图常用的工具程序员效率整理常用的在线笔记软件远程办公常用的远程协助软件你都知道吗51单片机程序下载、ISP及串口基础知识硬件断路器、接触器、继电器基础知识