MySQL的mysqldump命令使用详解
核心提示:MySQL有很多可以导进数据的方法,但是这些只是数据传输中的1半,另外的1般是从MySQL数据库中导出数据。有很多的缘由我们需要导出数据。1个重要的缘由是用于备份数据库。数据的造价常常是昂贵的,需要谨慎处理它们。常常地备份可以帮助避免宝贵数据地丢失;另外1个原
MySQL有很多可以导进数据的方法,但是这些只是数据传输中的1半,另外的1般是从MySQL数据库中导出数据。有很多的缘由我们需要导出数据。1个重要的缘由是用于备份数据库。数据的造价常常是昂贵的,需要谨慎处理它们。常常地备份可以帮助避免宝贵数据地丢失;另外1个缘由是,或许您希看导出数据来共享。 在这个信息技术不断成长的世界中,共享数据变得越来越常见。
比方说Macmillan USA保护护着1个将要出版的书籍的大型数据库。这个数据库在很多书店之间共享,这样他们就知道哪些书将会很快出版。医院越来越走向采取无纸病历记录,这样这些病历可以随时随着你。世界变得越来越小,信息也被共享得越来越多。有很多中导出数据得方法,它们都跟导进数据很类似。由于,究竟,这些都只是1种透视得方式。从数据库导出的数据就是从另1端导进的数据。这里我们其实不讨论其他的数据库各种各样的导出数据的方法,您将学会如何用MySQL来实现数据导出。
使用mysqldump:(mysqldump命令位于mysql/bin/目录中)
mysqldump工具很多方面类似相反作用的工具mysqlimport。它们有1些一样的选项。但mysqldump能够做更多的事情。它可以把全部数据库装载到1个单独的文本文件中。这个文件包括有所有重建您的数据库所需要的SQL命令。这个命令取得所有的模式(Schema,后面有解释)并且将其转换成DDL语法(CREATE语句,即数据库定义语句),取得所有的数据,并且从这些数据中创建INSERT语句。这个工具将您的数据库中所有的设计倒转。由于所有的东西都被包括到了1个文本文件中。这个文本文件可以用1个简单的批处理和1个合适SQL语句导回到MySQL中。这个工具使人难以置信地简单而快速。决不会有半点让人头疼地地方。
因此,假设您像装载全部数据库Meet_A_Geek的内容到1个文件中,可使用下面的命令:
bin/mysqldump –p Meet_A_Geek > MeetAGeek_Dump_File.txt
这个语句也答应您指定1个表进行dump(备份/导出/装载?)。假设您只是希看把数据库Meet_A_Geek中的表Orders中的全部内容导出到1个文件,可使用下面的命令:
bin/mysqldump –p Meet_A_Geek Orders >MeetAGeek_Orders.txt
这个非常的灵活,您乃至可使用WHERE从句来选择您需要的记录导出到文件中。要到达这样的目的,可使用类似于下面的命令:
bin/mysqldump –p –where="Order_ID > 2000" Meet_A_Geek Orders > Special_Dump.txt
mysqldump工具有大量的选项,部份选项以下表:
选项/Option 作用/Action Performed
--add-drop-table
这个选项将会在每1个表的前面加上DROP TABLE IF EXISTS语句,这样可以保证导回MySQL数据库的时候不会出错,由于每次导回的时候,都会首先检查表是否是存在,存在就删除
--add-locks
这个选项会在INSERT语句中捆上1个LOCK TABLE和UNLOCK TABLE语句。这就避免在这些记录被再次导进数据库时其他用户对表进行的操纵
-c or - complete_insert
这个选项使得mysqldump命令给每1个产生INSERT语句加上列(field)的名字。当把数据导出导另外1个数据库时这个选项很有用。
--delayed-insert 在INSERT命令中加进DELAY选项
-F or -flush-logs 使用这个选项,在履行导出之前将会刷新MySQL服务器的log.
-f or -force 使用这个选项,即使有毛病产生,依然继续导出
--full 这个选项把附加信息也加到CREATE TABLE的语句中
-l or -lock-tables 使用这个选项,导出表的时候服务器将会给表加锁。
-t or -no-create- info
这个选项使的mysqldump命令不创建CREATE TABLE语句,这个选项在您只需要数据而不需要DDL(数据库定义语句)时很方便。
-d or -no-data 这个选项使的mysqldump命令不创建INSERT语句。
在您只需要DDL语句时,可使用这个选项。
--opt 此选项将打开所有会进步文件导出速度和创造1个可以更快导进的文件的选项。
-q or -quick 这个选项使得MySQL不会把全部导出的内容读进内存再履行导出,而是在读到的时候就写进导文件中。
-T path or -tab = path 这个选项将会创建两个文件,1个文件包括DDL语句或表创建语句,另1个文件包括数据。DDL文件被命名为table_name.sql,数据文件被命名为table_name.txt.路径名是寄存这两个文件的目录。目录必须已存在,并且命令的使用者有对文件的特权。
-w "WHERE Clause" or -where = "Where clause "
如前面所讲的,您可使用这1选项来过挑选将要放到 导出文件的数据。
假定您需要为1个表单中要用到的帐号建立1个文件,经理要看今年(2004年)所有的定单(Orders),它们其实不对DDL感爱好,并且需要文件有逗号分隔,由于这样就很轻易导进到Excel中。 为了完成这个人物,您可使用下面的句子:
bin/mysqldump –p –where "Order_Date >='2000-01-01'"
–tab = /home/mark –no-create-info –fields-terminated-by=, Meet_A_Geek Orders
这将会得到您想要的结果。
schema:模式
The set of statements, expressed in data definition language, that completely describe the structure of a data base.
1组以数据定义语言来表达的语句集,该语句集完全地描写了数据库的结构。
SELECT INTO OUTFILE :
假设您觉得mysqldump工具不够酷,就使用SELECT INTO OUTFILE吧, MySQL一样提供1个跟LOAD DATA INFILE命令有相反作用的命令,这就是SELECT INTO OUTFILE 命令,这两个命令有很多的类似的地方。首先,它们有所有的选项几近相同。现在您需要完成前面用mysqldump完成的功能,可以依照下面的步骤进行操纵:
1. 确保mysqld进程(服务)已在运行
2. cd /usr/local/mysql
3. bin/mysqladmin ping ;// 假设这个句子通不过,可以用这个:mysqladmin -u root -p ping
mysqladmin ping用于检测mysqld的状态,is alive说明正在运行,出错则可能需要用户名和密码。
4. 启动MySQL 监听程序.
5. bin/mysql –p Meet_A_Geek;// 进进mysql命令行,并且打开数据库Meet_A_Geek,需要输进密码
6. 在命令行中,输进1下命令:
SELECT * INTO OUTFILE '/home/mark/Orders.txt'
FIELDS
TERMINATED BY = ','
FROM Orders
WHERE Order_Date >= '2000-01-01'
在你按了Return(回车)以后,文件就创建了。这个句子就像1个规则的SELECT语句,只是把想屏幕的输出重定向到了文件中。这意味这您可使用JOIN来实现多表的高级查询。这个特点也能够被用作1个报表产生器。
比方说,您可以组合这1章中讨论的方法来产生1个非常有趣的查询,试试这个:
在mysql目录建立1个名为Report_G.rpt 的文本文件,加进下面的行:
USE Meet_A_Geek;
INSERT INTO Customers (Customer_ID, Last_Name, First_Name)
VALUES (NULL, "Kinnard", "Vicky");
INSERT INTO Customers (Customer_ID, Last_Name, First_Name)
VALUES (NULL, "Kinnard", "Steven");
INSERT INTO Customers (Customer_ID, Last_Name, First_Name)
VALUES (NULL, "Brown", "Sam");
SELECT Last_Name INTO OUTFILE '/home/mark/Report.rpt'
FROM Customers WHERE Customer_ID > 1;
然后确认 mysql进程在运行,并且您在mysql目录中, 输进下面的命令:
bin/mysql < Report_G.rpt检查您命名作为输出的文件,这个文件将会包括所有您在Customers表中输进的顾客的姓。 如您所见,您可使用今天学到的导进/导出(import/export)的方法来帮助得到报表。
唐山网站建设www.fw8.netTAG:数据,文件,命令,选项,语句
评论加载中...
|