PHP-范式

编程之家收集整理的这篇文章主要介绍了PHP-范式编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

范式:Normal Format规定的一种设计方式

范式特点:范式有很多,从低级到高级有六级左右,低级往高级一级比一级要求严格。

关系型数据库通常设计只需要满足其中一半,满足第三范式即可。满足第三范式必须先满足第二范式,第二范式又必须先满足第一范式。


第一范式:1NF

数据表的设计的字段中,每个字段都不能再分,每个字段都必须是最小的不可分割的单位(原子性)
讲师代课表

这里写图片描述

要知道每个老师是从哪天开始上课的?
因为代课时间的起始和结束时间都需要单独用来使用,而当前的设计需要将数据进行处理才能实现目的,那么这种设计方式违背了第一范式(原子性)

要满足第一范式,只需要将代课时间分为起始时间和结束时间即可

这里写图片描述

满足第一范式:只要保证字段拿出来可以直接使用而不需要加工即可。


第二范式:2NF

一个数据表中的字段只能依赖一张表中的全部主键,而不能够依赖部分主键(主键是复合主键),第二范式的任务就是取消部分依赖。
讲师代课表

这里写图片描述


以上采用复合主键来保证记录的唯一性(讲师和班级)
但是上面有一个问题:教室字段受班级影响,教室字段并不是手整个主键(讲师+班级)的影响,而是受主键的部分(班级)影响,该设计违背了第二范式

解决方案:取消复合主键,额外增加一个逻辑主键(不参与业务处理)

这里写图片描述

满足第二范式:在表中尽量不使用复合主键,使用逻辑主键


第三范式:3NF

在第二范式的前提上,如果在一个表中,出现了的数据会在其他实体(表)中出现,那么该类数据就应该统一拿出来新建一张表来进行维护。如果一个字段,依赖一个表中的飞主键字段,这个时候就称之为传递依赖,就应该将该字段以及依赖的字段取出,重新维护一张表。
讲师代课表

这里写图片描述

上述设计满足第一范式和第二范式,教室依赖班级存在,性别依赖讲师存在,那么就存在传递依赖。
解决方案:将讲师和性别单独拿出来维护一张表,在代表表中使用讲师对应的主键;班级和教室也单独拿出来维护一张表,带课表中使用班级对应的主键。

这里写图片描述

满足第三范式:不同的实体创建不同的表,实体之间有关联的话,增加一个字段保存对应其他实体中记录的主键
满足第三范式主要解决数据冗余的问题。

范式是一种规范,但是在数据库的设计的时候,有时候会根据实际的需求,进行适当的数据的冗余,这种设计就称之为逆规范化。
逆规范化:权衡效率和磁盘空间占用问题。

具体以后的数据库该怎么设计?
1.要尽量满足三范式
2.考虑实际情况,如果一个字段在一张表的查询过程非常频繁的被使用,那么就可以考虑逆规范化在该使用数据字段对应id的使用,使用实际的数据字段代替。

总结

以上是编程之家为你收集整理的PHP-范式全部内容,希望文章能够帮你解决PHP-范式所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢寻找一群志同道合、互帮互助的学习伙伴,可以点击下方链接加入:
编程之家官方1群
编程之家官方2群
编程之家官方3群
编程之家官方4群

相关文章

猜你在找的PHP相关文章

字符串函数 strlen:获取字符串的长度,获取的是字符串的字节长度 字符:一个完整的符号,a,中 字节:由8位组成 一个字符最少等于一个字节:ASCII码,a,b,通常英文字符都是占用一个字节 中文在gbk或者gb2312编码里,占用两个字节 中文在utf-8里最少占用3个字节,有可能是4个字节 substr:截取字符串,以字节为单位截取 string sub...
1.什么php? 一种服务器端的 HTML 脚本/编程语言,是一种简单的、面向对象的、解释型的、健壮的、安全的、性能非常之高的、独立于架构的、可移植的、动态的脚本语言。是一种广泛用于 Open Source(开放源代码)的尤其适合 Web 开发并可以嵌入 HTML 的多用途脚本语言。它的语法接近 C,Java 和 Perl,而且容易学习。该语言让 Web 开发人员快速的书写动态生成的网页。P...
范式:Normal Format规定的一种设计方式范式特点:范式有很多,从低级到高级有六级左右,低级往高级一级比一级要求严格。关系型数据库通常设计只需要满足其中一半,满足第三范式即可。满足第三范式必须先满足第二范式,第二范式又必须先满足第一范式。第一范式:1NF数据表的设计的字段中,每个字段都不能再分,每个字段都必须是最小的不可分割的单位(原子性) 讲师代课表 要知...
自然界中实体与实体之间的联系如何在数据库中进行体现。多对一/一对多1.需求:有一个学生表一张班级表 一个学生只属于一个教室,一个教室却包含多个学生。这种关系就称之为多对一或者一对多的关系 多对多2.需求:有一个教师表和一个学生表 一个学生被多个老师教过,一个老师教过多个学生,这个关系就称之为多对多的关系 一对一3.需求:一个学生信息,有10种信息,其...
mysql中也分为三大数据类型:数值型,字符型,时间日期型 数值型数值型分为整数型和小数型(包含小数部分的数据类型)整型mysql中光整数型数据类型就有五种:tinyint,smallint,mediumint,int,bigint tinyint:迷你整型,占用1个字节保存数据,能够表示256个数值 smallint:小整型,占用2个字节保存数据,能够表示6...
存储引擎:处理和保存数据的方式。主要存储引擎是InnoDB和Myisam InnoDB:会创建一个结构文件,数据和索引都放在ibdata1文件里 Myisam:创建三个文件,结构,索引和数据mysql存储引擎 引擎因为费用的问题分为两类 免费:InnoDB和Myisam都是免费 收费:BDB,memory,archive都是收费 Myisam与I...
1.mytable1存储的数据是utf8字符集(在创建表的时候,指定了表的数据存储字符集为utf8)2.cmd控制台只能是gbk格式的数据:说明cmd下只能输入和显示gbk格式的数据3.set names gbk的功能 客户端与服务端进行不同编码的通信的原理 了解数据库的字符集 查看数据库支持哪些字符集?show character set; mysql支持39种字...
数据库词汇数据:data,凡是能携带信息的媒介都是数据 硬盘数据:保存在磁盘中,以二进制形式保存 内存数据:运行在内存中 数据库:Database,高效存储和处理数据的媒介(凡是存放数据的地方都可以称之为数据库),数据库分为两大阵营:关系型数据库,非关系型数据库。 数据库系统:Database System = DBMS +DB,DBMS(Database Manage...
微信公众号搜索 “ 程序精选 ” ,选择关注!
微信公众号搜 "程序精选"关注