数据库基础
- 什么是数据库
- 主流数据库
- 数据库的基本使用
- 连接服务器
- 服务器管理
- 服务器、数据库、表之间的关系
- 数据库基本指令
- MySQL架构
- SQL分类
- 存储引擎
- 什么是存储引擎
- 查看存储引擎
- 存储引擎对比
什么是数据库
存储数据用文件就可以了,为什么还要弄个数据库?
文件保存数据有以下几个缺点:
文件的安全性问题
文件不利于数据查询和管理
文件不利于存储海量数据
文件在程序中控制不方便
一般的文件确实提供了数据的存储功能,但是文件并没有提供非常好的数据管理能力
为了更加有效的管理数据,所以就出现了数据库
mysql是一套给我们提供数据存取的服务的网络程序
数据库一般指的是,在磁盘或者内存中存储的特定结构组织的数据—将来在磁盘上存储的一套数据库方案
数据库本质:对数据内容存储的一套解决方案
数据库存储介质有磁盘和内存
- mysql是数据库服务的客户端
- mysqld是数据库服务的服务器端
- mysql本质:基于C(mysql)S(mysqld)模式的一种网络服务
主流数据库
- SQL Sever:微软的产品,.Net程序员的最爱,中大型项目。
- Oracle:甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。
- MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的SQL处理效果好。
- SQLite: 是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。
数据库的基本使用
连接服务器
mysql -h 127.0.0.1 -P 3306 -u root -p
-h
:指名登陆部署了mysql服务的主机
-P
:指名我们要访问的端口号
-u
:知名登录用户
-p
:指名需要输入密码如果没有写
-h 127.0.0.1
默认是连接本地如果没有写
-P 3306
默认是连接3306端口号
服务器管理
- 执行win+r输入services.msc打开服务管理器
- 通过下图左侧停止、暂停、重启动进行服务管理
服务器、数据库、表之间的关系
使用mysql建立一个数据库,再建立一张表结构,插入一些数据—mysql在Linux中是如何表现的?
-
建立数据库,本质就是Linux下的一个目录,数据库服务存放在
/var/lib/mysql
目录下 -
在数据库内建立表,本质就是在Linux下创建对应的文件即可
-
数据库本质其实也是文件!!只不过这些文件不由程序员直接操作,而是由数据库服务器帮我们进行操作
所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库,一般来说开发人员对每一个应用创建一个数据库。
为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据。
数据库服务器、数据库和表的关系如下:
数据库基本指令
-
创建数据库
create database ST;
-
使用数据库
use ST;
-
创建数据库表
create table student(id int,name varchar(32),gender varchar(2) );
-
表中插入数据
insert into student (id, name, gender) values (1, '张三', '男'); insert into student (id, name, gender) values (2, '李四', '女'); insert into student (id, name, gender) values (3, '王五', '男');
-
查询表中的数据
select * from student;
MySQL架构
MySQL是一个可移植的数据库,几乎能在当前所有的操作系统上运行,如Unix/Linux、Windows、Mac等。各种系统在底层实现方面各有不同,但是MySQL基本上能保证在各个平台上的物理体系结构的一致性。
第一层:解决安全和连接管理问题
第二层:进行词法语法分析、sql语句优化
第三层:具体完成数据存储方案
第四层:依赖文件系统,把数据以二进制方式存到特定目录下,然后构建特定普通文件,把数据存储好
从系统来看:
-
用户进程:第一、二、三层
-
操作系统:第四层
从网络来看:
- 应用层:第一、二、三层
- 内核层:第四层
SQL分类
-
DDL【data definition language】 数据定义语言,用来维护存储数据的结构
代表指令:
create, drop, alter
-
DML【data manipulation language】 数据操纵语言,用来对数据进行操作
代表指令:
insert,delete,update
- DML中又单独分了一个DQL,数据查询语言,代表指令: select
-
DCL【Data Control Language】 数据控制语言,主要负责权限管理和事务
代表指令:
grant,revoke
-
TCL 【Transaction Control Language】 事务控制语言,用于管理事务,控制数据操作的提交或回滚。
代表指令:
commit, rollback, savepoint,set transaction
存储引擎
什么是存储引擎
存储引擎:数据库管理系统如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。
MySQL的核心就是插件式存储引擎,支持多种存储引擎。
查看存储引擎
show engines;