MySQL用作备份还原的导入和导出命令用法整理
mysqldump
命令行导出数据库:
1,进入MySQL目录下的bin文件夹:cdMySQL中到bin文件夹的目录
如我输入的命令行:cdC:\ProgramFiles\MySQL\MySQLServer4.1\bin
2,导出数据库:mysqldump-u用户名-p数据库名>导出的文件名
如我输入的命令行:mysqldump-uroot-pnews>news.sql (输入后会让你输入进入MySQL的密码)
(如果导出单张表的话在数据库名后面输入表名即可)
3、会看到文件news.sql自动生成到bin文件下
命令行导入数据库:
1,将要导入的.sql文件移至bin文件下,这样的路径比较方便
2,同上面导出的第1步
3,进入MySQL:mysql-u用户名-p
如我输入的命令行:mysql-uroot-p (输入同样后会让你输入ySQL的密码)
4,在MySQL-Front中新建你要建的数据库,这时是空数据库,如新建一个名为news的目标数据库(mysql>createdatabasenews;)
5,输入:mysql>use目标数据库名
如我输入的命令行:mysql>usenews;
6,导入文件:mysql>source导入的文件名;
如我输入的命令行:mysql>sourcenews.sql;
实例:
导出
#>cd/usr/local/src #>/usr/local/mysql/bin/mysqldump-uroot-p123456cacti>cacti.sql;
这样就看到cacti.sql导出到了/usr/local/src/目录
1.导出整个数据库
mysqldump-u用户名-p数据库名>导出的文件名 mysqldump-uroot-pabc>abc.sql
2.导出一个表
mysqldump-u用户名-p数据库名表名>导出的文件名 mysqldump-uroot-pabcusers>abc_users.sql
3.导出一个数据库结构
mysqldump-uroot-p-d--add-drop-tableabc>/usr/local/abc_db.sql -d没有数据--add-drop-table在每个create语句之前增加一个droptable
导入
#>/usr/local/mysql/bin/mysql-uroot-p mysql>createdatabasecacti;新建数据库名为cacti mysql>usecacti;选择目标数据库 mysql>source/usr/local/src/cacti.sql导入数据库
这样就导入了cacti.sql文件
loaddata
(windows系统。。表结构一致的情况下)
命令在DOS的mysql/bin目录下执行:
导出:
select*fromaaaintooutfile"e:/a.txt";
导入:
loaddatalocalinfile"e:/a.txt"intotableaaa;
备份:SELECTINTOOUTFILE
SELECT*FROMhx_9enjoyINTOOUTFILE'/tmp/9enjoy.txt'
默认使用tab分割字段,记录使用/n分割。可以自定义三个参数。
SELECT*FROMhx_9enjoyINTOOUTFILE'/tmp/9enjoy_hx.txt'FIELDSTERMINATEDBY','OPTIONALLYENCLOSEDBY'"'LINESTERMINATEDBY'/n';
即使用,分割字段,双引号限定字段内容,/n分割记录。
还可以指定某些条件的记录输出:
SELECT*FROMhx_9enjoyWHEREid<100INTOOUTFILE'/tmp/9enjoy_100.txt'
还原:LOADDATAINFILE
默认情况:
LOADDATAINFILE'/tmp/9enjoy.txt'INTOTABLEhx_9enjoy
如果有指定界定符,则加上界定符的说明:
LOADDATAINFILE'/tmp/9enjoy.txt'INTOTABLEhx_9enjoyFIELDSTERMINATEDBY','OPTIONALLYENCLOSEDBY'"'LINESTERMINATEDBY'/n'
如果db是GBK或utf-8等编码,需要在还原时指定CHARACTERSET参数,否则还原的数据是乱码。
如:
loaddatainfile'/tmp/9enjoy.txt'INTOTABLEhx_9enjoyCHARACTERSETgbk;
注意事项
1.mysql必须要有权限访问生成文件的那个目录
2.由于安全方面的原因,不能覆盖已存在的文件,不管这个文件的权限是怎么分配的。
3.不能直接导出一个压缩文件。