当前位置:七道奇文章资讯数据防范MySQL防范
日期:2011-01-25 22:43:00  来源:本站整理

MySQL数据导入导出办法与工具介绍[MySQL防范]

赞助商链接



  本文“MySQL数据导入导出办法与工具介绍[MySQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
1).mysqlimport的语法介绍: ?=|T^5slg  
mysqlimport位于mysql/bin目录中,是mysql的一个载入(大概说导入)数据的一个非常有效的工具.这是一个号令行工具.有两个参数以及大量的选项可供挑选.这个工具把一个文本文件(text file)导入到你指定的数据库和表中.比方说我们要从文件Customers.txt中把数据导入到数据库Meet_A_Geek中的表 Custermers中: C\t"i  +3  
mysqlimport Meet_A_Geek Customers.txt /"M1WP6l  
注意:这里Customers.txt是我们要导入数据的文本文件,而Meet_A_Geek是我们要操作的数据库,数据库中的表名是Customers,这里文本文件的数据格局必须与Customers表中的记录格局一致,不然mysqlimport号令将会出错. By 5o#s7q  
此中表的名字是导入文件的第一个句号(.)前面文件字符串,别的一个例子: 8Z[iHx@  
mysqlimport Meet_A_Geek Cus.to.mers.txt gcb%"Z `  
那么我们将把文件中的内容导入到数据库Meet_A_Geek 中的Cus表中.上面的例子中,都只用到两个参数,并没有效到更多的选项,下面介绍mysqlimport的选项.
2).mysqlimport的常用选项介绍: Kso7 :  
  选项         功效 iaT#JP(C  
-d or --delete   新数据导入数据表中之前删除数据数据表中的全部信息 c(a+'P  
-f or --force   不管能否碰到错误,mysqlimport将强迫持续插入数据 f+9p9;MKP"  
-i or --ignore   mysqlimport跳过大概忽视那些有相同唯一关键字的行, 导入文件中的数据将被忽视. X:{2.e )  
-l or -lock-tables 数据被插入之前锁住表,这样就避免了,你在更新数据库时,用户的查询和更新遭到影响. FhT'_~  
-r or -replace   这个选项与-i选项的作用相反;此选项将替换表中有相同唯一关键字的记录. s? G}q  
--fields-enclosed- by= char Ra8;UYA  
      指定文本文件中数据的记录时以什么括起的, 很多情形下数据以双引号括起. 默许的情形下数据是没有被字符括起的. C`'C (,=\  
--fields-terminated- by=char HRME2Wc  
      指定各个数据的值之间的脱离符,在句号脱离的文件中,脱离符是句号.您可以用此选项指定数据之间的脱离符.默许的脱离符是跳格符(Tab) "R6(1y/X  
--lines-terminated- by=str jJb[peoa  
      此选项指定文本文件中行与行之间数据的脱离字符串大概字符. 默许的情形下mysqlimport以newline为行脱离符. kbAX5w0t.  
      您可以挑选用一个字符串来替换一个单个的字符:一个新行大概一个回车. ?GVI(8IF  
mysqlimport号令常用的选项还有-v 显示版本(version), -p 提醒输入密码(password)等.
3).例子:导入一个以逗号为脱离符的文件文件中行的记录格局是这样的: e! Ia?u  
"1", "ORD89876", "1 Dozen Roses", "19991226" UO(jW )>N  
我们的任务是要把这个文件里面的数据导入到数据库Meet_A_Geek中的表格Orders中,我们利用这个号令: t cy&J  
bin/mysqlimport –prl –fields-enclosed-by=" –fields-terminated-by=, Meet_A_Geek Orders.txt R!uaQ>QU  
这个号令大概看起来很不爽,不过当你熟习了之后,这是非常简单的. yteX9ej7  
第一部份,bin/mysqlimport ,奉告操作系统你要运行的号令是mysql/bin目录下的mysqlimport,选项p是要求输入密码,这样就要求你在窜改数据库之前输入密码,操作起来会更安全.我们用了r选项是因为我们想要把表中的唯一关键字与文件记录中有反复唯一关键字的记录替换成文件中的数据.我们表单中的数据不是最新的,需求用文件中的数据去更新,因而就用r这个选项,替换数据库中已经有的记录.l选项的作用是在我们插入数据的时刻锁住表,这样就禁止了用户在我们更新表的时刻对表举行查询大概更改的操作. #jT!,I^  
n:x9_@gO4  
-------------------------------------------------------------------------------- G46P7l?  
从 MySQL 导入导出大量数据的程序实现办法 d06 JTN  
http://www.cx66.com/cxgzs/tips/00773.htm S\M@0Mo  
大家一定利用过 phpmyadmin 里面的数据库导入,导出功效,非常便利.但是在实际利用中,我发现以下几个问题: ^jXgg>>+V,  
1、数据库超越一定尺寸,比方6M 这时利用导出普通没问题,可以精确的保存到本机硬盘上面,但是导入则不行!缘由是:普通的 PHP.INI 里面设置暂时文件/上传文件的大小限制为2M,而phpmyadmin利用了上传的方法,造成失利. DiB! 2%g  
2、导出到硬盘的 .SQL 文件在导回时,常常呈现由于某些单引号的问题惹起失利,造成导入失利,只能用 mysql等利用程序导入了.  @eYvpfz  
我的数据库已经超越10M,所以必须办理这个问题.我的思绪: Zv|Q=t  
导出: 用phpmyadmin 保存数据库/表格构造,用脚本读取数据库内容并保存到文件里面! b^Nm:T  
导入: 用phpmyadmin 恢复数据库/表格构造,用脚本读取文件,然后保存到库里面! } lIA=  
ts}s&~4z  
导出程序以下:调用办法为 ****.php?table=tablename tOO_@=  
这个简单的程序目前一次保存一个表格!!每行为一个字段的数据!! YuOR")a  
LI\~ 7BJ  
g=)Lvj  
if($table=="")exit(); v_U,K;P  
mysql_connect("localhost","name","password"); NTZ2.H284  
mysql_select_db("database"); T2M@V  
$result = mysql_query("select * from $table"); eU$hQ/r  
if(mysql_num_rows($result) < = 0) exit(); d( G<wc/  
echo "开始转换数据到文本... [.(b4g7R*%  
"; ]-(]/b '  
$handle = fopen("$table.txt","w"); %S_]m9hN  
$numfields = mysql_num_fields($result); GJ+r@RQp  
fputs($handle,$numfields." "); DC1$`MDD  
for($k=0;$k 7EZg9x?/.  
{ 8k*\z1^=M;  
$msg = mysql_fetch_row($result); G|7 z)}-  
for($i=0;$i< $numfields;$i++) ip1k~}1<  
{ AqK<WW+a  
$msg[$i] = str_replace(" ","&&php2000mysqlreturn&&",$msg[$i]); ;!x81omV?  
$msg[$i] = str_replace(" " ,"&&php2000mysqlreturn&&",$msg[$i]); LoY)[3u(X  
fputs($handle,$msg[$i]." "); A 4?%)Bv  
} n%(O!6  
fputs($handle,"------- php2000 dump data program V1.0 for MySQL -------- "); > ^|xa>*  
} 0m1R#^<lV  
fclose($handle); 78d}XJQV  
echo "ok"; g[DVi  
?> Lzfwy(  
kOCsy6j8  
导入的程序以下:用法同上面! NF{a>2+B  
if($table=="")exit(); G? .uy"  
mysql_connect("localhost","name","password"); 8'a5iVd  
mysql_select_db("database"); <>Z+w[ ;  
$message = file("$table.txt"); iSo'f\uQ  
echo $numfields = chop($message[0]); rdG[-z:mC  
for($k=1;$k )EaR#m 1  
{ b 1rYrgo i  
$value=""; EjT bI6'  
for ($i=$k;$i< ($k+$numfields-1);$i++) ah(&<\p,  
{ ?m9k=cy  
$tmp = str_replace("&&php2000mysqlreturn&&"," ",chop($message[$i])); +Y)"VFYB  
$value .= "'".addslashes($tmp)."',"; 5p:}@Zhw#  
} rV3vY}Qsz  
$tmp = str_replace("&&php2000mysqlreturn&&"," ",chop($message[$k+$numfields-1])); x H3(Y o%  
$value .= "'".$tmp."'"; l5V7(V?.X  
$query = "insert into $table values (".$value.")"; -Dr zN]  
echo mysql_error(); IEGZ`5>8  
mysql_query($query); 8}ec"0^g  
echo $k." "; y(~Xf<0"}b  
} ?FP[>3<  
echo "ok"; N^rN_A@)  
?>
利用办法和大概的问题! XYBn;%Hd}  
1、导入时 file()函数大概会有问题(我的10M的数据没呈现问题),可以改成 fopen()然后没次读一行!! D JmJ0W.  
2、导入,导出都需求用 ftp 操作,也就是导出后,用 ftp 把数据转到本机,导入时先用ftp转移数据到服务器! %duj&rhBo  
mysql数据库常用导出导入号令的几个用例 CFFZ$M@  
================================ `vijqOJ}  
几个常用用例: &GrKJ+N:u  
1.导出整个数据库 0Q_b<'a  
mysqldump -u 用户名 -p 数据库名 > 导出的文件名 %5 'EI6q  
mysqldump -u WCNC -p smgp_apps_WCNC > WCNC.sql

2.导出一个表 i nkdq!?'  
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名 9X-' m  
mysqldump -u WCNC -p smgp_apps_WCNC users> WCNC_users.sql 5 Ot-|$S^  
3.导出一个数据库构造 Ur !ab5`  
mysqldump -u WCNC -p -d --add-drop-table smgp_apps_WCNC >d:WCNC_db.sql i;h{L(/2  
ETXG9B(  
-d 没有数据 --add-drop-table 在每个create语句之前增添一个drop table b]QUhDx,N  
pl9HL<j  
4.导入数据库 V 0B|3  
常用source 号令 dh2vI/R6J>  
进入mysql数据库掌握台, B;| Sm  
如mysql -u root -p I'?4_'oA  
[QXnk"Eh  
mysql>use 数据库 %6'O".l:  
Hg)b;8UV3  
然后利用source号令,背面参数为脚本文件(如这里用到的.sql) wr=}6ei@M  
mysql>source d:WCNC_db.sql
可参看 MySQL数据的导出和导入工具:mysqldump 20W`q17>aY  
tu^4cg50`{  
==================================== ylbA<26hc"  
ey%PK  
MySQL数据导入导出办法与工具介绍之二 Z9\mB)f  
4hmhGnY.  
批处理是一种非交互式运行mysql程序的办法,好像您在mysql中利用的号令一样,你仍旧将利用这些号令.为了实现批处理,您重定向一个文件到 mysql程序中,首先我们需求一个文本文件,这个文本文件包含有与我们在mysql中输入的号令相同的文本.比方我们要插入一些数据,利用包含下面文本的文件(文件名为New_Data.sql,当然我们也可以取名为New_Data.txt及任何其他的合理名字,并不一定要今后缀sql末尾): 4#4fpDQ  
SF@pVFp  
Kd.ZwL+  
USE Meet_A_Geek; .^g3?o  
INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Block"); Gx=sj')  
INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Newton"); .=a~Tcg   
INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Simmons"); +3k9jO1sU  
)u,Q$z*6  
注意上面的这些句子的语法都必须是精确的,并且每个句子以分号完毕.上面的USE号令挑选数据库,INSERT号令插入数据. `q~aZ+  
3VGsZN $Z  
下面我们要把上面的文件导入到数据库中,导入之前要确认数据库已经在运行,便是mysqld进程(大概说服务,Windows NT下面称为”服务“,unix下面为”进程“)已经在运行.然后运行下面的号令: ^'jhlQ3  
bin/mysql –p < /home/mark/New_Data.sql $H\MSjV#  
接着按提醒输入密码,假如上面的文件中的语句没有错误,那么这些数据就被导入到了数据库中. XabVf3  
jB~R  
号令行中利用LOAD DATA INFILE 从文件中导入数据到数据库: Q>Yo^U,X  
目前您大概会问自己,"毕竟为什么我要输入全部的这些SQL语句到文件中,然后通历程序运行它们呢?”这样看起来仿佛需求大量的工作.很好,你这样想极大概就对了.但是假定你有从全部这些号令中产生的log记录呢?目前这样就很棒,嗯,大大都数据库城市自动产生数据库中的事件记录的log.而大部份log都包含有效过的原始的SQL号令.因此,假如您不能从您目前的数据库中导出数据到新的mysql数据库中利用,那么您可以利用log和mysql的批处理特点,来快速且便利地导入您地数据.当然,这样就省去了打字的麻烦. f3S~iGf2  
LOAD DATA INFILE EYlT/V{  
这是我们要介绍的最后一个导入数据到MySQL数据库中的办法.这个号令与mysqlimport非常类似,但这个办法可以在mysql号令行中利用.也就是说您可以在全部利用API的程序中利用这个号令.利用这种办法,您便可以在利用程序中导入您想要导入的数据. \o}fG! 1a  
3FM B* P  
利用这个号令之前,mysqld进程(服务)必须已经在运行.启动mysql号令行: }q=|AcXD  
bin/mysql –p -*5tvZk  
按提醒输入密码,成功进入mysql号令行之后,输入下面的号令: R2,`kWnr  
USE Meet_A_Geek; Pz%-OOKg  
LOAD DATA INFILE "/home/mark/data.sql" INTO TABLE Orders; aUE e)  
简单的讲,这样将会把文件data.sql中的内容导入到表Orders中,如mysqlimport工具一样,这个号令也有一些可以挑选的参数.比方您需求把自己的电脑上的数据导入到远程的数据库服务器中,您可以利用下面的号令: 57n,n\B@  
LOAD DATA LOCAL INFILE "C:\MyDocs\SQL.txt" INTO TABLE Orders; R37 0  
上面的LOCAL参数表示文件是本地的文件,服务器是您所登陆的服务器.这样就省去了利用ftp来上传文件到服务器,MySQL替你完成了. uoA$"La"O  
rWfe-;j  
您也可以设置插入语句的优先级,假如您要把它标志为低优先级(LOW_PRIORITY),那么MySQL将会等到没有其他人读这个表的时刻,才把插入数据.可以利用以下的号令: >, /S;8<  
LOAD DATA LOW_PRIORITY INFILE "/home/mark/data.sql" INTO TABLE Orders; T^;9_MF  
您也可以指定能否在插入数据的时刻,代替大概忽视文件与数据表中反复的键值.替换反复的键值的语法: T$Ya.Tb{  
LOAD DATA LOW_PRIORITY INFILE "/home/mark/data.sql" REPLACE INTO TABLE Orders;  ^BFDg5}  
上面的句子看起来有点拙笨,但却把关键字放在了让您的解析器可以理解的地方. k 7W-AV  
C({2Q$H}  
下面的一对选项描写了文件的记录格局,这些选项也是在mysqlimport工具中可以用的.他们在这里看起来有点差别.首先,要用到FIELDS关键字,假如用到这个关键字,MySQL解析器但愿看到至少有下面的一个选项: w][}p  
TERMINATED BY character [Q ra[-i  
ENCLOSED BY character u3 iAb$ns<  
ESCAPED BY character #ucS4c  
这些关键字与它们的参数跟mysqlimport中的用法是一样的. The 9SkY,N~4(  
TERMINATED BY 描写字段的脱离符,默许情形下是tab字符(\t) G29AmQMeJ  
ENCLOSED BY描写的是字段的括起字符.比方以引号括起每一个字段. WPr x  
ESCAPED BY 描写的转义字符.默许的是反些杠(backslash:\ ). 0'5+}sU S  
下面仍旧利用前面的mysqlimport号令的例子,用LOAD DATA INFILE语句把一样的文件导入到数据库中: =ze";Nmk K  
LOAD DATA INFILE "/home/mark/Orders.txt" REPLACE INTO TABLE Orders FIELDS TERMINATED BY ',' Un<%iy/.c  
ENCLOSED BY '"'; q3F&!2  
LOAD DATA INFILE语句中有一个mysqlimport工具中没有特点:LOAD DATA INFILE 可以按指定的列把文件导入到数据库中. l |cLr a  
当我们要把数据的一部份内容导入的时刻,这个特点就很重要.比方说,我们要从Access数据库进级到MySQL数据库的时刻,需求加入一些栏目(列/字段 /field)到MySQL数据库中,以适应一些额外的需求.这个时刻,我们的Access数据库中的数据仍旧是可用的,但是因为这些数据的栏目 (field)与MySQL中的不再匹配,因此而无法再利用mysqlimport工具.固然如此,我们仍旧可以利用LOAD DATA INFILE,下面的例子显示了若何向指定的栏目(field)中导入数据: Ww"Vfb]q  
LOAD DATA INFILE "/home/Order.txt" INTO TABLE Orders(Order_Number, Order_Date, Customer_ID); cma[=xTfHG  
如您所见,我们可以指定需求的栏目(fields).这些指定的字段仍然是以括号括起,由逗号脱离的,假如您遗漏了此中任何一个,MySQL将会提醒您^_^
  以上是“MySQL数据导入导出办法与工具介绍[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 .