Chinaunix首页 | 论坛 | 博客
  • 博客访问: 960483
  • 博文数量: 83
  • 博客积分: 32
  • 博客等级: 民兵
  • 技术积分: 2080
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-12 09:45
个人简介

努力学习,努力分享,努力.....在努力..努力离开..

文章分类

全部博文(83)

文章存档

2017年(3)

2015年(1)

2014年(47)

2013年(32)

分类: Mysql/postgreSQL

2013-10-26 22:38:32

一,数据库的备份与导入
1),数据库的备份
1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
例:mysqldump -u dbadmin -p my > /home/bw/blog/database_bak/my.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
例:mysqldump -u dbadmin -p my wp_users> /home/bw/blog/database_bak/blog_users.sql
3.导出一个数据库结构
mysqldump -u dbadmin -p -d --add-drop-table my > /home/bw/blog/database_bak/blog_struc.sql
说明:-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table
4.导出数据库一个表结构
mysqldump -u dbadmin -p -d --add-drop-table my  wp_users> /home/bw/blog/database_bak/blog_users_struc.sql
说明:-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table
2),数据库的导入
1,用 mysqldump 备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。
例如:
#/usr/local/mysql/bin/mysql -u root -p *****  my   < /home/bw/blog/database_bak/my.sql
这种方法,我以前经常现在很少用了,因为很容易产生乱码,因为:
a,导出数据库时,你如果忘了设置导出字符集的话,在导入的时候,就有可能会出问题.
b,假如,你导出时设置导出时设置了utf8的编码,但是你又把你的数据库现在的字符集改成了gb2312的.这样又会乱码。
2,用 source 语句
例如:
mysql -u dbadmin -p
use my;
set names utf8;  #这里的字符集根你的将要导入的数据库的字符集一至。
source /home/bw/blog/database_bak/my.sql;
二,文件的备份


1),文件的备份
你可以用tar命令来打包压缩你要备份的文件,然后用shell来让它定期备份。不过没有cpio来的方便
cpio命令参数:
-i 从标准输入中读取文件。
-o 从标准输入中读出路径名清单并且拷贝文件到标准输出中。
-p 从标准输入中读出文件路径名清单。
-c 以 ASCII 字符的形式读写头信息,便于移植。。
-d 创建需要的目录
-u 无条件的复制(通常,旧文件不能用相同的文件名替代新文件)。
-m 保留先前文件的修改时间。这个选项在拷贝目录的时候不起作用。
-v 详细的,列出文件名称列表。
[root@BlackGhost bw]# find /home/bw/test -type f|cpio -o > /home/bw/test.cpio
31 blocks
[root@BlackGhost bw]# ls -al |grep cpio
-rw-r--r--  1 root   root  15872 Feb  8 15:10 test.cpio
2),文件的还原
cd /home/bw/test
ls
aaa.cpio  test.cpio  test.tar.gz
rm *.*         #删除该文件夹下面的所以测试文件
ls
cpio -i < /home/bw/test.cpio          #导入以前的备份文件
31 blocks
ls
aaa.cpio  test.cpio  test.tar.gz
简单吧,我觉得挺简单的。
阅读(1412) | 评论(0) | 转发(0) |
0

上一篇:mysql分区-truncate

下一篇:mysql错误对照表

给主人留下些什么吧!~~