1.什么是数据库?
数据库:database,存储数据的仓库
标准定义:高效的存储和处理数据的介质(介质主要是两种:磁盘和内存)。
2. 数据库的分类?
数据库基于存储介质的不同:分为两类:关系型数据库(SQL)和非关系型数据库(NoSQL:Not Only SQL),不是关系型的数据库都叫做非关系型数据库。
3.不同的数据库阵营中的产品有哪些?
关系型数据库
大型:Oracle、DB2
中型:SQL SERVER,Mysql等
小型:access
非关系型数据库:memcached,mongodb,redis(持久化)
4.两种数据库阵营的区别?
关系型数据库:安全(保存磁盘基本不可能丢失),容易理解,比较浪费空间(二维表)
非关系型数据库:效率高,不安全(断电会丢失)
关系型数据库
1.什么是关系型数据库?
关系型数据库:是一种建立在关系模型(数学模型)上的数据库。
关系模型:一种所谓建立在关系上的模型,关系模型包含三个方面:
数据结构:解决数据存储的问题,二维表(有行和列)
操作指令集合:所有SQL语句
完整性约束:表内数据约束(字段与字段),表与表之间的约束(外键)
2.关系型数据库的设计?
关系型数据库:从需要存储的数据需求分析,如果是一类数据(实体)应该设计成一张二维表:表是由表头(字段名:用来规定数据的名字)和数据部分组成(实际存储的数据单元)
关系型数据库的特点之一:如果表中对应的某个字段没有值(数据),但是系统依然要分配空间:关系型数据库比较浪费空间。
关键字说明
数据库:database
数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼。
DBS= DBMS + DB
DBMS:Database Management System,数据库管理系统,专门管理数据库
DBA:Database Administrator,数据库管理员
行/记录:row/record,本质是一个东西:都是指表中的一行(一条记录);行是从结构角度出发,记录是从数据角度出发
列/字段:column/field,本质是一个东西。
SQL
SQL:Structure Query Language,结构化查询语言(数据以查询为主: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)可能内部会有一些细微的区别。
Mysql数据库
Mysql数据库是一种c/s结构的软件:客户端、服务端,若想访问服务器必须通过客户端(服务器一直运行,客户端在需要使用的时候运行)。
交互方式
1.客户端连接认证:连接服务器,认证身份:mysql.exe -hPup
mysql.exe -h localhost -uroot -P3306 -p 1234
2.发送SQL指令
show databases; 查看所有数据库
3.处理SQL指令:返回操作结果
4.客户端接收结果:显示结果
5.断开连接(释放资源:服务器并发限制)
exit
网友评论