快捷搜索:  as  2018  FtCWSyGV  С˵  test  xxx  Ψһ  w3viyKQx

澳门24小时0524:MySQL中的mysqldump命令使用详解(1)



MySQL有很多可以导入数据的措施,然而这些只是数据传输中的一半,别的的一样平常是从MySQL数据库中导出数据。有许多的缘故原由我们必要导出数据。一个紧张的缘故原由是用于备份数据库。数据的造价经常是昂贵的,必要审慎处置惩罚它们。常常地备份可以赞助防止宝贵数据地损掉;别的一个缘故原由是,大概您盼望导出数据来共享。 在这个信息技巧赓续生长的天下中,共享数据变得越来越常见。

比方说Macmillan USA掩护护着一个将要出版的册本的大年夜型数据库。这个数据库在许多书店之间共享,这样他们就知道哪些书将会很快出版。病院越来越走向采纳无纸病历记录,这样这些病历可以随时随着你。天下变得越来越小,信息也被共享得越来越多。有很多中导出数据得措施,它们都跟导入数据很相似。由于,终究,这些都只是一种透视得要领。从数据库导出的数据便是从另一端导入的数据。这里我们并不评论争论其他的数据库各类各样的导出数据的措施,您将学会若何用MySQL来实现数据导出。

应用mysqldump:

(mysqldump敕令位于mysql/bin/目录中)

mysqldump对象很多方面类似相反感化的对象mysqlimport。它们有一些同样的选项。但mysqldump能够做更多的工作。它可以把全部数据库装载到一个零丁的文本文件中。这个文件包孕有所有重修您的数据库所必要的SQL敕令。这个敕令取得所有的模式(Schema,后面有解释)并且将其转换成DDL语法(CREATE语句,即数据库定义语句),取得所有的数据,并且从这些数据中创建INSERT语句。这个对象将您的数据库中所有的设计倒转。由于所有的器械都被包孕到了一个文本文件中。这个文本文件可以用一个简单的批处置惩罚和一个相宜SQL语句导回到MySQL中。这个对象令人难以置信地简单而快速。决不会有半点让人头疼地地方。

是以,假如您像装载全部数据库Meet_A_Geek的内容到一个文件中,可以应用下面的敕令:

bin/mysqldump –p Meet_A_Geek > MeetAGeek_Dump_File.txt

这个语句也容许您指定一个表进行dump(备份/导出/装载?)。假如您只是盼望把数据库Meet_A_Geek中的表Orders中的全部内容导出到一个文澳门24小时0524件,可以应用下面的敕令:

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

这个选项将会在每一个表的前面加上DROP TABLE IF EXISTS语句,这样可以包管导回MySQL数据库的时刻不会掉足,由于每次导回的时刻,都邑首先反省表是否存在,存在就删除

--add-locks

这个选项会在INSERT语句中捆上一个LOCK TABLE和UNLOCK TABLE语句。这就防止在这些记录被再次导入数据库时其他用户对表进行的操作

-c or - complete_insert

这个选项使得mysqldump敕令给每一个孕育发生INSERT语句加上列(field)的名字。当把数据导出导别的一个数据库时这个选项很有用。

--delayed-insert 在INSERT敕令中加入DELAY选项

-F or -flush-logs 应用这个选项,在履行导出之前将会刷新MySQL办事器的log.

-f or -force 应用这个选项,纵然有差错发生,仍旧继承导出

--full 这个选项把附加信息也加到CREATE TABLE的语句中

一组以数据定义说话来表达的语句集,该语句集完备地描述了数据库的布局。

SELECT INTO OUTFILE :

假如您感觉mysqldump对象不敷酷,就应用SELECT INTO OUTFILE吧, MySQL同样供给一个跟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澳门24小时0524/mysql –p Meet_A_Geek;// 进入mysql敕令行,并且打开数据库Meet_A_Geek,必要输入密码

6. 在敕令行中,输入一下敕令:

SELECT * INTO OUTFILE '/home/mark/Orders.txt'

FIELDS

TERMINATED 澳门24小时0524BY = ','

FROM Orders

WHERE Order_Date >= '澳门24小时0524;2000-01-01'  在你按了Return(回车)之后,文件就创建了。这个句子就像一个规则的SELECT语句,只是把想屏幕的输出重定向到了文件中。这意味这您可以应用JOIN来实现多表的高档查询。这个特征也可以被用作一个报表孕育发生器。

比方说,您可以组澳门24小时0524合这一章中评论争论的措施来孕育发生一个异常有趣的查询,试试这个:

在mysql目录建立一个名为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)的措施来赞助获得报表。

您可能还会对下面的文章感兴趣: