目录

数据库操作
创建数据库
创建数据库的语法如下:
sql
create database [if not exists] db_name [create_specification [,
create_specification] ...]
create_specification:
[default] character set charset_name
[default] collate collation_name
character为编码集,collate为设置校验集。
如下所示:

同时查看/var/lib/mysql文件,发现多了一个目录:

创建数据库的本质,是在/var/lib/mysql创建一个目录,也可以通过在/var/lib/mysql目录中新建文件夹来创建数据库,不过这样不推荐。
使用数据库可以用use db_name指令,若要查看用户当前处在哪一个数据库下,可以使用select database()指令;查看数据库创建时的指令为show create database db_name。
数据库编码集
创建数据库的时候,有两个编码集,一个是数据库编码集,一个是数据库校验集。
数据库编码集对应存储数据的编码集,数据库校验集用来支持数据库进行字段比较使用的编码,本质也是一种读取数据库中数据的采用的编码格式。数据库无论对数据做任何操作,都必须保证操作和编码必须是编码一致的。
查看系统默认支持的编码集,命令如下:
sql
show variables like 'character_set_database';
查看系统默认支持的校验集命令,如下:
sql
show variables like 'collation_database';
查看数据库支持的全部字符集:
sql
show charset;
查看数据库支持的字符集校验规则:
sql
show collation;
删除数据库
删除数据库的命令如下:
sql
drop database [if exists] db_name;
删除数据库,本质就是删除对应的目录。
修改数据库
修改数据库的命令如下:
sql
alter database db_name
[alter_specification [,alter_specification]...]
库的备份与恢复
数据库备份的命令如下:
bash
mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径
示例如下所示:

查看对应的sql文件,如下所示:

注意,如果备份一个数据库时,没有带上-B参数,在恢复数据库时,需要先创建空数据库,然后使用数据库,再进行还原。
恢复数据库的指令如下:
bash
source 数据库备份存储的文件路径;
如果要备份数据库中的几张表,命令如下:
sql
mysqldump -u root -p 数据库名 表名1 表名2 > 数据库备份存储的文件路径
如果要备份多个数据库,命令如下:
sql
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径
查看数据库连接情况
sql
show processlist
如下所示:

数据库表操作
创建表
数据库创建表的操作语法如下:
sql
create table [if not exists] table_name (
field1 datatype [comment '对应的描述'],
field2 datatype [comment '对应的描述'],
field3 datatype [comment '对应的描述']
) [character set 字符集 collate 校验规则 engine 存储引擎];
示例如下:

查看对应的数据库文件:

我们发现,不同的存储引擎,对应的文件个数也不一样。
查看表
查看数据库中的表命令如下:
sql
show tables;
如果要查看某一个表的详细信息,命令如下:
sql
desc tablename;
查看创建表时的详细信息:
sql
show create table tablename \G;
其中'\G'代表格式化显示,将不需要的符号去掉。
修改表结构
修改表的命令如下:
sql
alter table old_tablename rename to new_tablename;
alter table tablename add (column datatype [DEFAULT expr][,column
datatype]...);
alter table tablename modify (column datatype [DEFAULT expr][,column
datatype]...);
alter table tablename drop (column);
alter table tablename change old_columnname new_columnname datatype;
修改相关属性列,是通过直接覆盖来实现的。
删除表
删除表的命令如下:
sql
drop table table_name