单进程服务器-epool、数据库

1、阻塞 I/O 只能阻塞一个 I/O 操作,而 I/O 复用模型能够阻塞多个 I/O 操作,所以才叫做多路复用

2、采用epoll模型时创建了一个共享的内存空间,操作系统采用事件通知的方式,使一个进程能同时等待多个文件描述符

3、这样就可以同时监听多个网络连接 IO, 相对于多进程、多线程切换的开销问题,IO 多路复用可以极大的提升系统效率。

数据库(Database):存储数据的仓库

高效地存储和处理数据的介质(介质主要是两种:磁盘和内存)

数据库的分类

基于存储介质的不同:分为关系型数据库(SQL)和非关系型数据库(NoSQL:Not Only SQL)

关系型数据库

大型:Oracle、DB2

中型:SQL Server、MySQL

小型:Access等

非关系型数据库:Memcached、MongoDB、Redis

两种数据库阵营的区别

关系型数据库:安全(保存磁盘,基本不可能丢失),容易理解,比较浪费空间(二维表)

非关系型数据库:效率高,不安全(断电丢失)

是一种建立在关系模型(数学模型)上的数据库

关系模型:一种所谓建立在关系上的模型

关系模型包含三个方面:

数据结构:用于解决数据存储的问题,二维表(有行和列)

操作指令集合:所有SQL语句

完整性约束:表内数据约束(字段与字段)、表与表之间约束(外键)

从需要存储的数据需求中分析,如果是一类数据(实体)应该设计成一张二维表:表是由表头和数据部分组成

表头:即字段名,用来规定数据的名字

数据部分:实际存储的数据单元

关系型数据库,需要维护实体内部、实体与实体之间的联系

如果表中对应的某个字段没有值(数据),但是系统依然要分配空间,所以说关系型数据库比较浪费空间

SQL:(Structured Query Language,结构化查询语言)

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等

1、客户端连接认证:连接服务器、认证身份(mysql.exe -hPup)

2、客户端发送SQL指令

3、服务器接收SQL指令,并处理SQL指令,返回操作结果

4、客户端接收结果,并显示结果

5、断开连接

系统(DBMS)数据库(DB)数据表(Table)字段(Field)库操作表操作(包含字段操作)数据操作

create database 数据库名字 [库选项];

库选项:用来约束数据库,分为两个选项

字符集设定:charset/character set 具体字符集(数据存储的编码格式,常用的有:GBK和UTF8)

校对集设定:collate 具体校对集(数据比较的规则)

数据库名字不能用关键字(已经被系统使用的字符)或者保留字(将来系统可能会用到的字符)

创建结果:

在数据库系统中,增加了对应的数据库信息

会在保存数据的文件夹下(Data目录),创建一个对应数据库名字的文件夹

每个数据库下都有一个opt文件,保存了库选项

查看所有数据库:show databases;

查看指定部分的数据库(模糊查询):show databases like 'pattern';

pattern是匹配模式

%表示匹配多个字符

_表示匹配单个字符

查看数据库的创建语句:show create database 数据库名字

你可能感兴趣的:(单进程服务器-epool、数据库)