当前位置:七道奇文章资讯数据防范MySQL防范
日期:2011-05-02 15:44:00  来源:本站整理

MySQL中的mysqldump号令利用详解[MySQL防范]

赞助商链接



  本文“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.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的语句中

  -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 "

  如前面所讲的,您可以利用这一选项来过挑选将要放到 导出文件的数据.
  
  假定您需求为一个表单中要用到的帐号成立一个文件,经理要看本年(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.

  一组以数据定义语言来表达的语句集,该语句集完好地描写了数据库的构造.
  
  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/mysql –p Meet_A_Geek;// 进入mysql号令行,并且翻开数据库Meet_A_Geek,需求输入密码

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

  SELECT * INTO OUTFILE '/home/mark/Orders.txt'
  FIELDS
  TERMINATED BY = ','
  FROM Orders
  WHERE 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)的办法来帮忙得到报表.

  以上是“MySQL中的mysqldump号令利用详解[MySQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • Windows 搭配 IIS7 PHP MySQL 环境
  • mysql Out of memory (Needed 16777224 bytes)的错误办理
  • mysql提醒[Warning] Invalid (old?) table or database name问题的办理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • MySQL Order By语法介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • mysql数据库插入速度和读取速度的调整记录
  • MySQL Order By索引优化办法
  • MySQL Order By用法分享
  • mysql #1062 –Duplicate entry ''1'' for key ''PRIMARY''
  • MySQL Order By Rand()效率解析
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .