数据库基础
数据库:database
高效的存储和处理数据的介质(磁盘和内存)
数据库的分类
基于存储介质的不同:关系型数据库(SQL)和非关系型数据库(NoSQL)
关系型数据库:安全(保存磁盘基本不可能丢失),容易理解;比较浪费空间(二维表)
非关系型数据库:效率高,不安全(断电丢失)
关系型数据库
1、什么是关系型数据库
定义:关系型数据库是一种建立在关系模型(数据模型)上的数据库。
关系模型:一种所谓建立在关系上的模型。
关系模型包含三个方面:
- 数据结构:数据存储的问题,二维表(有行和列)
- 操作指令集合:所有SQL语句
- 完整性约束:表内数据约束(字段与字段)、表与表之间约束(外键)
关系型数据库的设计
从需要存储的数据需求中分析,如果是一类数据(实体)应该设计成一张二维表。
表:表是由表头(字段名:用来规定数据的名字)和数据部分组成(实际存储的数据单元)
关系型数据库的特点:
如果表中对应的某个字段没有值(数据),但是系统依然要分配空间。(关系型数据库比较浪费空间)
关键字说明
数据库:DB(database)
数据库系统:DBS(Database System):是一种虚拟系统,讲各种内容关联起来的称呼
DBS=DBMS+DB
DBMS:Datebase Management System,数据库管理系统,专门管理数据库
DBA:Database Administrator,数据库管理员
行/记录:row/record,本质是一个东西,都是指表中的一行(一条语句),行是从结构的角度出发,记录是从数据记录的角度出发
列/字段:column/field,本质是一个东西
SQL
SQL:structured Query Language,结构化查询语言
SQL分为三部分
DDL:Data Definition Language,数据定义语言,用来维护存储数据的结构(数据库,表)
代表指令:create,drop,alter
DML:Data Manipulation Language,数据操作语言,用来对数据进行操作(数据表中的内容)
代表指令:insert,delete,update;其中DML内部又单独进行了一个分类:DQL(Date Query language):数据查询语言
DCL:Data Control Language,数据控制语言,主要负责权限管理(用户)
代表指令:grant,revoke
Mysql数据库
Mysql数据库是一种c/s结构的软件:客户端/服务端,若想访问服务器必须通过客户端(服务器一直运行,客户端在使用的时候运行)。
交互方式:
1、客户端连接认证:连接服务器,认证身份:mysql.exe -h主机名(localhost) -P端口(3306) -u用户(root) -p
2、客户端发送SQL指令
3、服务器接收SQL指令:处理指令,返回操作结果
4、客户端接收结果:显示结果
5、断开连接(释放资源:服务器并发限制)
Mysql服务器对象
将MySQL服务器内部对象分成了四层:系统(DBMS)->数据库(DB)->数据表(Table)->字段(field)