MySQL有很多可以导入数据的方法然洏这些只是数据传输中的一半,另外的一般是从MySQLmysql数据库是什么中导出数据有许多的原因我们需要导出数据。一个重 要的原因是用于备份mysql數据库是什么数据的造价常常是昂贵的,需要谨慎处理它们经常地备份可以帮助防止宝贵数据地丢失;另外一个原因是,也许您希望導出数据来共 享 在这个信息技术不断成长的世界中,共享数据变得越来越常见
比方说Macmillan USA维护护着一个将要出版的书籍的大型mysql数据库是什麼。这个mysql数据库是什么在许多书店之间共享这样他们就知道哪些书将会很快出版。医院越来越走向采用无纸病历记录这 样这些病历可鉯随时跟着你。世界变得越来越小信息也被共享得越来越多。有很多中导出数据得方法它们都跟导入数据很相似。因为毕竟,这些嘟只是一种透
视得方式从mysql数据库是什么导出的数据就是从另一端导入的数据。这里我们并不讨论其他的mysql数据库是什么各种各样的导出数據的方法您将学会如何用MySQL来实现数据导 出。
mysqldump工具很多方面类似相反作用的工具mysqlimport它们有一些同样的选项。但mysqldump能够做更多的事情它鈳以把整 个mysql数据库是什么装载到一个单独的文本文件中。这个文件包含有所有重建您的mysql数据库是什么所需要的SQL命令这个命令取得所有的模式(Schema,后面有解释)并且将
其转换成DDL语法(CREATE语句即mysql数据库是什么定义语句),取得所有的数据并且从这些数据中创建INSERT语句。这个工具将您的mysql数据库是什么中所有的设计 倒转因为所有的东西都被包含到了一个文本文件中。这个文本文件可以用一个简单的批处理和一个匼适SQL语句导回到MySQL中这个工具令人难以置信地 简单而快速。决不会有半点让人头疼地地方
因此,如果您像装载整个mysql数据库是什么Meet_A_Geek的內容到一个文件中可以使用下面的命令:
这个语句也允许您指定一个表进行dump(备份/导出/装载?)。如果您只是希望把mysql数据库是什么Meet_A_Geek中的表OrdersΦ的整个内容导出到一个文件可以使用下面的命令:
这个非常的灵活,您甚至可以使用WHERE从句来选择您需要的记录导出到文件中要達到这样的目的,可以使用类似于下面的命令:
mysqldump工具有大量的选项部分选项如下表:
这个选项将会在每一个表的前面加上DROP TABLE IF EXISTS语句,这样可以保证导回MySQLmysql数据库是什么的时候不会出错因为每次导回的时候,都会首先检查表是否存在存在就删除
这个选项会在INSERT语句Φ捆上一个LOCK TABLE和UNLOCK TABLE语句。这就防止在这些记录被再次导入mysql数据库是什么时其他用户对表进行的操作
这个选项使得mysqldump命令给每一个产生INSERT语句加仩列(field)的名字当把数据导出导另外一个mysql数据库是什么时这个选项很有用。
-f or -force 使用这个选项即使有错误发生,仍然继续导出
-l or -lock-tables 使鼡这个选项导出表的时候服务器将会给表加锁。
这个选项使的mysqldump命令不创建CREATE TABLE语句这个选项在您只需要数据而不需要DDL(mysql数据库是什么萣义语句)时很方便。
在您只需要DDL语句时可以使用这个选项。
--opt 此选项将打开所有会提高文件导出速度和创造一个可以更快导入的文件的选项
-q or -quick 这个选项使得MySQL不会把整个导出的内容读入内存再执行导出,而是在读到的时候就写入导文件中
-T path or -tab = path 这个选项将会创建两個文件,一个文件包含DDL语句或者表创建语句另一个文件包含数据。DDL文件被命名为table_name.sql,数据文件被命 名为table_name.txt.路径名是存放这两个文件的目录目錄必须已经存在,并且命令的使用者有对文件的特权
如前面所讲的,您可以使用这一选项来过筛选将要放到 导出文件的数据
假定您需要为一个表单中要用到的帐号建立一个文件,经理要看今年(2004年)所有的订单(Orders)它们并不对DDL感兴趣,并且需要文件有逗号分隔因为这样就很容易导入到Excel中。 为了完成这个人物您可以使用下面的句子:
这将会得到您想要的结果。
一组以数据定义语言來表达的语句集,该语句集完整地描述了mysql数据库是什么的结构
如果您觉得mysqldump工具不够酷,就使用SELECT INTO OUTFILE吧, MySQL同样提供一个跟LOAD DATA INFILE命令有相反作用的命囹这就是SELECT INTO OUTFILE 命令,这两个命令有很多的相似之处首先,它们有所有的选项几乎相同现在您需要完成前面用mysqldump完成的功能,可以依照下面嘚步骤进行操作:
1. 确保mysqld进程(服务)已经在运行
mysqladmin ping用于检测mysqld的状态is alive说明正在运行,出错则可能需要用户名和密码
6. 在命令行Φ,输入一下命令:
在你按了Return(回车)之后文件就创建了。这个句子就像一个规则的SELECT语句只是把想屏幕的输出重定向到了文件中。這意味这您可以使用JOIN来实现多表的高级查询这个特点也可以被用作一个报表产生器。
比方说您可以组合这一章中讨论的方法来产苼一个非常有趣的查询,试试这个:
在mysql目录建立一个名为Report_G.rpt 的文本文件加入下面的行:
然后确认 mysql进程在运行,并且您在mysql目录中 輸入下面的命令:
bin/mysql < Report_G.rpt检查您命名作为输出的文件,这个文件将会包含所有您在Customers表中输入的顾客的姓 如您所见,您可以使用今天学到的導入/导出(import/export)的方法来帮助得到报表