0x00
数据库备份:
mysqldump -u db_user -p db_passwd db_name > 1.sql//备份指定数据库
mysqldump -udb_user -pdb_passwd -A> 1.sql //备份所有数据库
数据库还原:
法1
mysql -u db_user -p db_passwd db_name < 1.sql //还原指定数据库
cd /var/lib/mysql
法2
mysql -u db_name -p
input passwd 进入mysql控制台mysql>
mysql> show databases;看看有哪些数据库
mysql> create database test ; 建立要还原的数据库
mysql> use test;切换到刚创建的数据库
mysql> source test.sql; 导入数据库
0x01 实操演示-备份全部数据库,删除恢复
1,备份全部数据库的数据和结构
mysqldump -uroot -pqwe -A > 1.sql
用户名:root 密码:qwe
注:这里的-pqwe
不能分开写-p qwe
不然会报错我也不知道为啥。。。
2,然后进入数据库删除一个数据库。
登录进数据库:
mysql -u root -p
Enter password:qwe
查看有哪些数据库:
show databases;
删除网站的数据库cltphp51_db
,可以发现cltphp51_db数据库已经被删除了:
drop database cltphp51_db;
这时候网站已经无法正常运作了,并且报错:无法连接数据库
3,然后我们再恢复数据库
建立要还原的数据库
create database cltphp51_db;
然后恢复它,不输入数据库名会恢复所有数据库:
mysql -uroot -pqwe < 1.sql
也可以指定数据库:
mysql -uroot -pqwe cltphp51_db < 1.sql
进入数据库发现数据库已经被恢复了:
网站也恢复正常了:
0x02 实操-备份单个数据库
mysqldump -uroot -pqwe cltphp51_db > test.sql;
root:用户名
qwe:密码
cltphp51_db:数据库名
方法1恢复:
mysqldump -uroot -pqwe cltphp51_db < test.sql
方法二,用source恢复
mysql> create database cltphp51_db;
mysql> use cltphp51_db;
mysql> source test.sql;
数据库已经被恢复: