(1)数据库:数据库 (DataBase, DB) 就是信息的集合或者说数据库是由数据库管理系统管理的数据的集合。
(2)数据库管理系统:数据库管理系统 (Database Management System, DBMS) 是一种操纵和管理数据库的大型软件,通常用于建立、使用和维护数据库。
(3)数据库系统:数据库系统 (Data Base System, DBS) 通常由软件、数据库和数据管理员 (DBA) 组成。
(4)数据库管理员:数据库管理员(Database Administrator, DBA) 负责全面管理和控制数据库系统。
(1)ER 图的全称是 Entity Relationship Diagram(实体联系图),提供了表示实体类型、属性和联系的方法。
(2)ER 图由下面 3 个要素组成:
(3)下图是一个学生选课的 ER 图,每个学生可以选若干门课程,同一门课程也可以被若干人选择,所以它们之间的关系是多对多 (M : N)。另外,还有其他两种实体之间的关系是:1 对 1 (1 : 1)、1 对多 (1 : N)。
主键 | 外键 | |
---|---|---|
定义 | 表用于唯一标识一条记录的一个或多个字段 | 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键 |
特点 | 不能为空,不能重复 | 只能引用外表中的列的值或用空值,可以重复 |
用途 | 唯一地标识一条记录;保证实体的完整性;加快数据库的操作速度 | 保持数据一致性、完整性;控制存储在外键表中的数据,使两张表形成关联(用来和其他表建立联系用的) |
(1)对于外键和级联,阿里巴巴开发手册这样说到:
【强制】不得使用外键与级联,一切外键概念必须在应用层解决。
说明:以学生和成绩的关系为例,学生表中的 student_id 是主键,那么成绩表中的 student_id 则为外键。如果更新学生表中的 student_id,同时触发成绩表中的 student_id 更新,即为级联更新。外键与级联更新适用于单机低并发,不适合分布式、高并发集群;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的插入速度。
(2)外键的缺点
当然,外键也有其优点:
① 保证了数据库数据的一致性和完整性;
② 级联操作方便,减轻了程序代码量;
(1)我们可以将存储过程看成是一些 SQL 语句的集合,并且中间加了点逻辑控制语句。
(2)存储过程在业务比较复杂的时候是非常实用的,比如很多时候我们完成一个操作可能需要写一大串 SQL 语句,这时候我们就可以写有一个存储过程,这样也方便了我们下一次的调用。存储过程一旦调试完成通过后就能稳定运行,另外,使用存储过程比单纯 SQL 语句执行要快,因为存储过程是预编译过的。
(3)存储过程在互联网公司应用不多,因为存储过程难以调试和扩展,而且没有移植性,还会消耗数据库资源。阿里巴巴 Java 开发手册里要求禁止使用存储过程。
(1)关系型数据库 (Relational Database Management System, RDBMS) 就是一种建立在关系模型的基础上的数据库。关系模型表明了数据库中所存储的数据之间的联系(一对一、一对多、多对多)。关系型数据库中,我们的数据都被存放在了各种表中(比如用户表),表中的每一行就存放着一条数据(比如一个用户的信息)。
(2)大部分关系型数据库都使用 SQL 来操作数据库中的数据。并且,大部分关系型数据库都支持事务的四大特性 (ACID)。常见的关系型数据库有:MySQL、PostgreSQL、Oracle、SQL Server、SQLite。
(1)SQL 是一种结构化查询语言 (Structured Query Language),专门用来与数据库打交道,目的是提供一种从数据库中读写数据的简单有效的方法。几乎所有的主流关系数据库都支持 SQL ,适用性非常强。并且一些非关系型数据库也兼容 SQL 或者使用的是类似于 SQL 的查询语言。
(2)SQL 可以帮助我们: