1.什么是数据库
数据库:database,存储数据的仓库。
数据库:高效的存储和处理数据的介质(介质主要是两种:磁盘和内存-RAM)。
2.数据库的分类
数据库基于存储介质的不同,进行了分类。
分为两类:关系型数据库(SQL)和非关系型数据库(NoSQL:Not Only SQL不是关系型的数据库都叫做非关系型数据库)。
3. 两类数据库的区别
关系型数据库:安全(保存磁盘基本不可能丢失),容易理解,比较浪费空间(二维表)。
非关系型数据库:效率高,不安全(保存在内存,断电丢失)。
4.什么是关系型数据库
1)什么是关系型数据库?
是一种建立在关系模型(数学模型)上的数据库【数据建模大赛】。
关系模型:一种所谓建立在关系上的模型。关系模型包含三个方面:
数据结构:数据存储的问题,二维表(有行和列)
操作指令集合:所有的SQL语句
完整性约束:表内数据约束(字段与字段),表与表之间的约束(外键)
2)数据库的设计
关系型数据库:从需要存储的数据需求中分析,如果是一类数据(实体)应该设计成一张二维表;
表是由表头(字段名:用来规定数据的名字)和数据部分组成(实际存储的数据单元);
二维表:行和列;
关系型数据库:维护实体内部,实体与实体之间的联系。
3)关系型数据库的特点之一:如果表中对应的某个字段没有值(数据),但是系统依然要分配空间(关系型数据库比较浪费空间)
.
4)关键字说明
数据库:DB(database)
数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼。
DBS=DBMS+DB
DBMS(Databade Management System):数据库管理系统,专门管理数据库。
DBA(Database Administrator)数据库管理员
行/记录:row / record,本质是一个东西,都是指表中的一行(一条记录)。
行是从
结构角度
出发,记录是从
数据角度
出发。
列/字段:column / field,本质是一个东西,都是指表中的一列(一个字段)。
列是从结构角度出发,字段是从数据角度出发。
5)SQL(Structured Query Language)
SQL,结构化查询语言(数据以查询为主,99%是在进行查询操作)
SQL分为三个部分
DDL(Data Definition Language)数据定义语言,用来维护存储数据的结构(
数据库,表
),代表指令:
create,drop,alter
等。
DML(Data Manipulation Language)数据操作语言,用来对数据进行操作(
数据表中的内容
),代表指令:
insert,delete,update
等,其中DML内部又单独进行了一个分类:DQL(Data Query Language)数据查询语言,如
select
。
--------表中的增删改查属操作语言
DCL(Data Control Language)数据控制语言,主要是负责权限管理(用户),代表指令:grant,revoke等。
SQL是关系型数据库的操作指令,SQL是一种约束,但不强制(类似W3C):不同的数据库产品(如Oracle,mysql)可能内部会有一些细微的区别。
------即某一数据库的SQL的操作指令在其他数据库中不一定能用。