2019-07-08

什么是数据库?

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

数据库的分类:

基于存储介质的不同:分为关系型数据库(sql)和非关系型数据库(nosql:not only sql)

不同数据库阵营的产品:

关系型数据库:
    大型:Oracle,DB2
    中型:SQL Server,MYSQL
    小型:Acces0s等
非关系型数据库:
    Memcached,MongoDB,Redis

两种
数据库阵营的区别:

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

什么是关系型数据库?

- 是一种建立在关系模型(数学模型)上的数据库
- 关系模型:一种所谓建立在关系上的模型
- 关系模型包含三个方面:
    数据结构:用于解决数据库存储的问题,二维表(有行和列)
    操作指令集合:所有sql语句
    完整性约束:表内数据约束(字段与字段),表与表之间约束(外键)
表是由表头和数据部分组成

表头:即字段名,用来规定数据的名字
数据部分:实际存储的数据单元

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

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

关键字说明

数据库:Database
数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼
    DBS = DBMS + DB
        DBMS:Database 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,数据操作语言)用来对数据进行操作(数据表中的内容),代表指令:一个分类;DQL(Data Query Language,数据查询语言)如select
    DCL:(Data Control Language,数据控制语言)主要是负责权限管理(用户),代表指令:grant,revoke等

···········

交互方式

1. 客户端连接认证:连接服务器,认证身份(mysql.exe -hPup)
2.客户端发送SQL指令
3.服务器接收SQL指令,并处理SQL指令,返回操作结果
4.客户端接收结果,并显示结果
5.断开连接:释放资源,因为服务器有并发限制

············

MySQL服务器对象

Mysql服务器内部对象分为四层:
系统(DBMS)
数据库(DB)
数据表(Table)
字段(Field)
···············

SQL基本操作

将SQL的基本操作根据操作对象进行分类,分为三类:
库操作
表操作(包含字段操作)
数据操作
···········

库操作

新增数据库
create database 数据库名字[库选项];
- 库选项:用来约束数据库,分为两个选项
    字符集设定:charset/character set 具体字符集(数据存储的编码格式,常用的有:GBK和UTF8)
    校对集设定:collate具体校对集(数据比较的规则)
- 数据库名字不能用关键字(已经被系统使用的字符)或者保留字(将来系统可能会用到的字符)
创建结果:
- 在数据库系统中,增加了对应的数据库信息
- 会在保存数据的文件夹下(Data目录),创建一个对应数据库名字的文件夹
- 每个数据库下都有一个opt文件,保存了库选项
查看数据库

查看所有数据库:

show database;

查看指定部分的数据库(模糊查询):

show database like 'pattern';
- pattern是匹配模式
- %表示匹配多个字符
- _表示匹配单个字符

查看数据库的创建语句:

show create database 数据库名字;

例:

-- 注释 (单行注释),也可以使用#号

-- 创建数据库
create database mydatabase
charset utf8;

create database database
charset utf8;

-- 创建中文数据库
create database 中国 charset utf8;
create database `中国` charset utf8;

-- 中文字符集
set names gbk;

-- 查看所有数据库
show database;

-- 创建数据库
create database informationtest
charset utf8;

-- 查看以information_开始的数据库(_需要被转义)
show database like 'information_';

-- 相当于information%
show database like 'information\_%';

-- 查看数据库的创建语句
show create database mydatabase;
show create database `database`;

你可能感兴趣的:(2019-07-08)