1、备份数据库
(1)使用mysqldump备份数据库mydb中的表student;
①:在E盘新建一个名为Study的文件,然后进入命令行模式,输入如下内容,然后回车
mysqldump -uroot -p123456 mydb student > E:\Study\student.sql
②:打开E盘的Study文件夹,里面多了一个student.sql文件,数据库mydb中的表student备份成功。
(2)使用mysqldump备份数据库mydb到C盘backup目录下;
①:在C盘创建一个名为backup的文件夹,然后进入命令行模式,输入如下内容,然后回车
mysqldump -uroot -p123456 mydb > C:\backup\mydb.sql
②:打开C盘的backup文件夹,里面多了一个mydb.sql文件,数据库mydb备份成功。
(3)备份MySQL服务器上所有数据库;
①:进入命令行模式,输入如下内容,回车
注:
因为在SQL语句中,单行注释用–(两个减号),所以,这里后面的–all-databases > C:\backup\all.sql被注释掉了,但是不管,直接把整行内容都给输入进去然后回车。MySQL中用命令一次性备份所有数据库的写法就是这样的。
mysqldump -uroot -p123456 --all-databases > C:\backup\all.sql
②:打开C盘的backup文件夹,里面多了一个all.sql文件,MySQL服务器上所有数据库备份成功。
2、恢复数据库
假设数据库mydb遭遇损坏,试用该数据库的备份文件mydb.sql将其恢复
注:
这里题目要求假设数据库mydb遭遇损坏,我所选择的损坏是直接删除数据库mydb。
①:在workbench中右击数据库mydb,点击Drop Schema,然后点击Drop Now,删除数据库mydb。
②:进入命令行模式,登录mysql
按照如下操作创建数据库mydb,创建成功后查看所有的数据库,确定数据库mydb在里面
注:
因为上面删掉了数据库mydb,那么,要想恢复数据库mydb,则必须先重新创建该名为mydb的数据库,然后再去输入下面步骤里的恢复命令并执行。否则,如果是在上面删除数据库mydb之后,没有先重新创建该名为mydb的数据库,直接输入下面步骤里的恢复命令并执行的话,则会报ERROR 1049 (42000): Unknown database 'mydb’的错误。
③:关掉此窗口,然后重新进入命令行模式,输入如下内容,回车
注:
一个小细节,这里是恢复数据库,因此中间写的是<,而如果是备份的话则中间写的是>。因为备份是导出,恢复是导入,导出用>,然后后面跟着路径,代表将数据库或者表导出到那个路径下,导入用<,然后后面跟着路径,代表从这个地方进行导入,导入该文件到相应的数据库中,结合着理解。
mysql -uroot -p123456 mydb < C:\backup\mydb.sql
补充:
这里在恢复数据库mydb的时候,也可以选择按照如下的方式来一下恢复所有的数据库。在命令行中输入如下内容,然后回车。这时要记得加上–default-character-set=utf8,因为MySQL默认以gbk编码连接数据库,而之前导出的备份文件是utf8编码,所以,如果不加上–default-character-set=utf8,则会因为编码不一致而导致错误。这里后面被注释掉的原因在上面备份所有数据库时已经解释过了,此处不再赘述。同样,这里也是直接把整行输入进去然后执行就好。值得注意的是,如果在第一步删除数据库mydb之后,不像第二步那样去重新创建名为mydb的数据库,然后接着恢复它,而是直接执行这步,恢复全部的数据库,则不会报上面所说的错误,而是会正常恢复好数据库mydb。
mysql -uroot -p123456 --default-character-set=utf8 < C:\backup\all.sql
⑤:进入workbench,可以看到先前删除的数据库mydb已被恢复,而且和原来的一样
3、用户管理
(1)使用MySQL新建一个用户“stu1”。
①:在workbench中输入如下内容,然后执行,成功创建用户“stu1”
注:
在这条命令中,第一个stu1是用户名,localhost是主机名,即用户连接 MySQL 时所用主机的名字,第二个stu1是密码。在MySQL中使用create user来创建用户的格式正是如此。这里补充一点,如果在创建用户的过程中,只给出了用户名,而没指定主机名,那么主机名默认为“%”,表示一组主机,即对所有主机开放权限。
create user 'stu1'@'localhost' identified by 'stu1';
(2)为“stu1”用户授权可以对mydb数据库中的学生表student进行查看、修改的权限。
①:在workbench中输入如下内容,然后执行
grant select, update on mydb.student to 'stu1'@'localhost';
②:输入如下内容,然后执行,查询“stu1”用户的权限,为“stu1”用户授权成功
show grants for 'stu1'@'localhost';
3)为“stu1”用户收回对mydb数据库中的学生表student进行修改的权限。
①:在workbench中输入如下内容,然后执行
revoke update on mydb.student from 'stu1'@'localhost';
②:输入如下内容,然后执行,查询“stu1”用户的权限,“stu1”用户对mydb数据库中的学生表student进行修改的权限已被删除
show grants for 'stu1'@'localhost';