创建数据库
创建数据库的代码:
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification] ...];
create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
说明:
-
大写的表示关键字
-
[] 是可选项
-
CHARACTER SET: 指定数据库采用的字符集
-
COLLATE: 指定数据库字符集的校验规则
注意:如果创建数据库未指明数据库的编码格式或效验规则,则默认使用MySQL配置文件中对应的编码格式或效验规则。
创建数据库案例
创建名为 db1 的数据库
create database db1;
说明:当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_ general_ ci
指定utf8编码格式创建数据库
我们可以通过charset指明数据库的编码格式,如下:
注意:SQL中的charset=utf8也可以写成charset set = utf8 或者charset set utf8.
创建数据库时通过charset和collater分别指明数据库的编码格式和效验规则即可。如下:
注意:SQL中的collate=utf8_general_ci,也可以写成collate_utf8_general_ci
操纵数据库
查看数据库
使用show database SQL可以查看系统中的所有数据库
显示创建语句
show create database db1;
说明一下:
- MySQL 建议我们关键字使用大写,但是不是必须的。
- 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字。
- /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话。
修改数据库
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
实例: 将 数据库字符集改成 gbk
删除数据库
DROP DATABASE [IF EXISTS] db_ name;
- 数据库内部看不到对应的数据库
- 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删
注意:不要随意删除数据库
备份和恢复 -- 放在最后
备份
语法:
mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径
为了演示数据库的备份和删除,我们先创建一个数据库再说
添加两条数据
查询看一看
mysqldump -P3306 -u root -p -B backup_and_restore > back.sql
打开back.sql的文件即可看到,文件的内容实际就是我们在这个数据库执行的各种SQL命令,包括创建数据库,创建表,修改表,插入语句等一系列语句;
恢复
现将原本的数据库删掉,show一下查看,放心没有了,接下来开始下面的工程
source back.sql
source 数据库的原路径
mysql> source D:/mysql-5.7.22/mytest.sql;
我们不难看出原本的数据库又回来了
实际恢复数据库的时候就是按照顺序执行数据库备份文件中的SQL语句,执行完毕后也就恢复出来了
同时该数据库中的表也恢复出来了
表的备份和恢复
新建一个老师表
表备份
mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql
同时备份多个表
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径
表恢复
source 表备份存储的文件路径
查看连接情况
使用show processlist SQL即可查看当前的链接MySQL的用户。
说明一下:
- Id列:一个标识,可以在MySQL中通过kill id杀死指定id的线程。
- User列:显示当前用户,如果不是root,这个命令就只显示你权限范围内的SQL语句。
- Host列:显示这个语句是从哪个IP的哪个端口上发出的,可用来追踪出问题语句的用户。
- db列:当前执行的命令是在哪一个数据库上,如果没有指定数据库,则该值为NULL。
- Command列:显示当前连接执行的命令,一般就是休眠(Sleep)、查询(Query)和连接(Connect)。
- Time列:表示该线程处于当前状态的时间,单位是秒。
- State列:显示使用当前连接的SQL语句的状态。
- Info列:一般记录的是线程执行的语句,默认只显示前100个字符,如果要看全部信息,需要使用show full processlist。
show processlist可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登录的,那么很有可能你的数据库被人入侵了,以后如果发现自己的数据库比较慢时,可以用这个SQL来查看数据库连接情况。