2022年MySQL中的mysqldump命令使用详解Mysql教程.docx
-
资源ID:62185884
资源大小:15.10KB
全文页数:10页
- 资源格式: DOCX
下载积分:9.9金币
快捷下载
![游客一键下载](/images/hot.gif)
会员登录下载
微信登录下载
三方登录下载:
微信扫一扫登录
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
|
2022年MySQL中的mysqldump命令使用详解Mysql教程.docx
2022年MySQL中的mysqldump命令使用详解Mysql教程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中的整个内容导出到一个文件,可以运用下面的吩咐:bin/mysqldump p Meet_A_Geek Orders >MeetAGeek_Orders.txt这个特别的敏捷,您甚至可以运用WHERE从句来选择您须要的记录导出到文件中。要达到这样的目的,可以运用类似于下面的吩咐:bin/mysqldump p where="Order_ID > 2000" Meet_A_Geek Orders > Special_Dump.txtmysqldump工具有大量的选项,部分选项如下表:选项/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的语句中-l or -lock-tables 运用这个选项,导出表的时候服务器将会给表加锁。-t or -no-create- info这个选项使的mysqldump吩咐不创建CREATE TABLE语句,这个选项在您只须要数据而不须要DDL(数据库定义语句)时很便利。-d or -no-data 这个选项使的mysqldump吩咐不创建INSERT语句。在您只须要DDL语句时,可以运用这个选项。-opt 此选项将打开全部会提高文件导出速度和创建一个可以更快导入的文件的选项。-q or -quick 这个选项使得MySQL不会把整个导出的内容读入内存再执行导出,而是在读到的时候就写入导文件中。-T path or -tab = path 这个选项将会创建两个文件,一个文件包含DDL语句或者表创建语句,另一个文件包含数据。DDL文件被命名为table_name.sql,数据文件被命名为table_name.txt.路径名是存放这两个文件的书目。书目必需已经存在,并且吩咐的运用者有对文件的特权。-w "WHERE Clause" or -where = "Where clause "如前面所讲的,您可以运用这一选项来过筛选将要放到 导出文件的数据。假定您须要为一个表单中要用到的帐号建立一个文件,经理要看今年(2022年)全部的订单(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.一组以数据定义语言来表达的语句集,该语句集完整地描述了数据库的结构。SELECT INTO OUTFILE :假如您觉得mysqldump工具不够酷,就运用SELECT INTO OUTFILE吧, MySQL同样供应一个跟LOAD DATA INFILE吩咐有相反作用的吩咐,这就是SELECT INTO OUTFILE 吩咐,这两个吩咐有许多的相像之处。首先,它们有全部的选项几乎相同。现在您须要完成前面用mysqldump完成的功能,可以依照下面的步骤进行操作:1. 确保mysqld进程(服务)已经在运行2. cd /usr/local/mysql3. bin/mysqladmin ping ;/ 假如这个句子通不过,可以用这个:mysqladmin -u root -p pingmysqladmin ping用于检测mysqld的状态,is alive说明正在运行,出错则可能须要用户名和密码。4. 启动MySQL 监听程序.5. bin/mysql p Meet_A_Geek;/ 进入mysql吩咐行,并且打开数据库Meet_A_Geek,须要输入密码6. 在吩咐行中,输入一下吩咐:SELECT * INTO OUTFILE '/home/mark/Orders.txt'FIELDSTERMINATED BY = ','FROM OrdersWHERE Order_Date >= '2000-01-01'在你按了Return(回车)之后,文件就创建了。这个句子就像一个规则的SELECT语句,只是把想屏幕的输出重定向到了文件中。这意味这您可以运用JOIN来实现多表的高级查询。这个特点也可以被用作一个报表产生器。比方说,您可以组合这一章中探讨的方法来产生一个特别好玩的查询,试试这个:在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)的方法来帮助得到报表。