创建数据库create
语法:
c
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification] ...]
create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
说明:
- 大写的表示关键字
-
\] 是可选项
- COLLATE: 指定数据库字符集的校验规则
例子 :
创建数据库 db_name------本质:在/var/lib/mysql创建一个目录
c
create database db_name;
删除数据库 db_name------本质:删除那个目录
c
drop database db_name;
创建前进行校验,是否已经创建数据库
create database if not exists db_name;
字符集与校验规则
创建数据库的时候,有两个编码集:
- 数据库编码集------数据库未来存储数据用的编码。
- 数据库校验集------支持数据库,进行字段比较使用的编码,本质是一种读取数据库中数据采用的编码格式。
一句话来说:数据通过字符集进行存储,通过校验规则进行查找。
例子 :两个数据库,用同一个字符集进行存储,用不同的校验规则进行读取。 两个数据库各建两张表,这两张表中都存储name(char)类型的A与a,然后进行查询(读取)。
- 校验规则使用utf8_ general_ ci(不区分大小写),仅查询a时,A,a都被查询。
- 校验规则使用utf8_ bin(区分大小写),仅查询a时,只有A或者a被查询。
甚至当多个字母(含大小写)插入表中时,进行排序,结果也是不一样的(校验规则会影响比较)
数据库无论对数据做任何操作,都必须保证操作和编码必须是编码一致的(数据的产生、传输、存储、读取" 全链路使用统一(或可兼容映射)的字符编码规则)。
字符集(Character Set)和校验规则(Collation)本质上是强关联、一一对应的核心关系------ 字符集定义 "能存储哪些字符",校验规则则定义 "这些字符该如何比较 / 排序",一套字符集必然对应一套或多套专属的校验规则,反之一个校验规则也只属于某一个字符集。
查看系统默认字符集以及校验规则
c
show variables like 'character_set_database';
show variables like 'collation_database';
注意:当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_ general_ c

查看数据库支持的字符集
show charset;结果如下
查看数据库支持的字符集校验规则show collation
给数据库设置编码(这里是创建时设置)
创建一个使用utf8字符集的 db_name 数据库
c
create database db_name charset=utf8;
create database db_name character set utf8;//两种写法
创建一个使用utf字符集,并带校对规则的 db_name 数据库。
c
create database db_name charset=utf8 collate utf8_general_ci;
操纵数据库
查看数据库show
c
show databases;
c
show tables
数据库删除drop
c
DROP DATABASE [IF EXISTS] db_ name;
结果:数据库文件夹被删除,里面的数据表全部被删,所以不要随便删除数据库。
修改数据库alter
语法:
c
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
注意:对数据库的修改主要指的是修改数据库的字符集,校验规则
例子:将 mytest 数据库字符集改成 gbk
c
alter database mytest charset=gbk;

备份和恢复
备份
语法:
c
mysqldump -P3306 -u root -p密码 -B 数据库名 > 数据库备份存储的文件路径
例:将helloworld库备份到文件(注:需要退出mysql,Bash命令)

这时,可以打开看看 mytest.sql 文件里的内容,其实把我们整个创建数据库,建表,导入数据的语句都装载这个文件中。

如果备份的不是整个数据库,而是其中的一张表,怎么做?
c
mysqldump -u root -p密码 数据库名 表名1 表名2 > 数据库存放路径
同时备份多个数据库
c
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径
还原
需要在连接mysql后进行还原
c
mysql> source 数据库文件所在的路径(xxx.sql所在路径);
本质上就是在执行一次所有的语句。
如果备份一个数据库时,没有带上-B参数,在恢复数据库时,需要先创建空数据库,然后使用数据库(切换到该数据库),在使用source来还原

