数据库的一些基础知识总结

了解SQL 一.什么是SQL SQL是结构化查询语言(Structured Query Language)的缩写。是一种专门用来与数据库通信的语言。 二.什么是数据库? 数据库(Database):保存有组织的数据的容器(通常是一个文件或一组文件)。 ​[scode type = “yellow”]需要注意的是,有时候我们把数据库软件也简称为数据库,但是数据库软件和数据库有本质区别,数据库软件应称为DBMS(数据库管理系统),我们通过数据库软件对数据库进行删减等操作,他代替你操作和访问数据库。[/scode] 三.数据库的组成 表 数据库中通常有多张表,这类似于一个清单。就好像我们管理两个班级就可以用两个表单。 表单之间用表名区分,在同一个数据库中不能有两个具有相同表名的表单。 行(又称记录) 在表中可以有很多行,我们可以把表看成一个二维数组。每一行代表了一个成员。 列 每一行有好多列,一列可以代表着成员的一个属性,例如id,班级,姓名等等······ 数据类型 每一列都有着特定的数据类型,例如字符串和数字就是两种不同的数据类型。 主键(primary key) 对于表中的每一行,我们都有一个唯一标识他的记号,这称作他的主键。 可以发现,主键有以下特征:1.每一行都必须有一个主键,不能为空。2.不同行的主键不同。 我们可以用多列作为主键,这样只需要确保多列组合起来的标识是唯一的。 外键(foreign key) 外键为某个表中的一列,它包含另一个表的主键值,定义了两个表之间的值,通过DBMS的操作可以将两个表联结起来。 通俗点讲,好比有两张表,分别存储了所有供应商的信息,和所有产品的信息,在前面那张表定义了每个供应商的id,作为其主键。然后我们为每个产品定义外键的id,填上对应供应商的id,然后通过连结,我们就能知道每个产品供应商的详细信息了。 可伸缩性(scale) 能够适应不断增加的工作量而不失败。设计良好的数据库或应用程序称之为可伸缩性好(scale well)。 四.数据库的连结 ​在上面我们讲外键的时候有讲到联结,连结的意思大概就是把多个表,根据一些命令串在一起。 等值连结(内部连结) 顾名思义,等值连结就是通过两个表之间元素值的相同来把两个表连结起来。 自联结 这个用于查找在同一表中某一特性相同的所有成员。有的时候自联结要比子查询快很多。 自然联结 在自然联结中,排除相同的列多次出现,使每个列只返回一次。 外部联结 联结包含了那些在相关表中没有关联行的行。这种类型的联结称为外部连结。 五.数据库设计范式 范式:当一个关系中的所有分类都是不可再分的数据项时,该关系是规范化的。不可再分的数据项,即不存在组合数据项和多项数据项。一个低一级的关系模式,通过模式分解可以转换为若干高一级范式的关系模式的集合,这个过程就叫规范化。 第一范式:当关系模式R的所有属性都不能在分解为更基本的数据单位时,称R是满足第一范式的,简记为1NF。满足第一范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。 第二范式:如果关系模式R满足第一范式,并且R得所有非主属性都完全依赖于R的每一个候选关键属性,称R满足第二范式,简记为2NF。 第三范式:设R是一个满足第一范式条件的关系模式,X是R的任意属性集,如果X非传递依赖于R的任意一个候选关键字,称R满足第三范式,简记为3NF。 用我们学长的一句话,范式不是必须满足的,但是我们尽量按照范式来设计数据库,毕竟这是这么多程序员实战经验总结出来的。 参考链接 数据库设计三大范式_dosthing 数据库设计三大范式_张龙豪 mysql必知必会

September 11, 2020 · zzsqwq