MySQL数据导入导出方法与工具介绍(1)

翻译声明:

本文内容来自Sams Teach Yourself MySQL in 21 Days一书的部分内容,by Mark Maslakowski

英文原文版权属原作者所有,中文的部分翻译有略有增删;原书讲的过于清楚的地方有删,讲的不清楚的地方有增;如果有翻译的不妥或者不正确的地方,请指正。

翻译者:David Euler,SCU. de_euler-david@www.yahoo.com.cn

时间:2004/04/24于川大

1).mysqlimport的语法介绍:

mysqlimport位于mysql/bin目录中,是mysql的一个载入(或者说导入)数据的一个非常有效的工具。这是一个命令行工具。有两个参数以及大量的选项可供选择。这个工具把一个文本文件(text file)导入到你指定的数据库和表中。比方说我们要从文件Customers.txt中把数据导入到数据库Meet_A_Geek中的表 Custermers中:

mysqlimport Meet_A_Geek Customers.txt

注意:这里Customers.txt是我们要导入数据的文本文件,而Meet_A_Geek是我们要操作的数据库,数据库中的表名是Customers,这里文本文件的数据格式必须与Customers表中的记录格式一致,否则mysqlimport命令将会出错。

其中表的名字是导入文件的第一个句号(.)前面文件字符串,另外一个例子:

mysqlimport Meet_A_Geek Cus.to.mers.txt

那么我们将把文件中的内容导入到数据库Meet_A_Geek 中的Cus表中。上面的例子中,都只用到两个参数,并没有用到更多的选项,下面介绍mysqlimport的选项。

2).mysqlimport的常用选项介绍:

选项 功能

-d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息

-f or --force 不管是否遇到错误,mysqlimport将强制继续插入数据

-i or --ignore mysqlimport跳过或者忽略那些有相同唯一关键字的行, 导入文件中的数据将被忽略。

-l or -lock-tables 数据被插入之前锁住表,这样就防止了,你在更新数据库时,用户的查询和更新受到影响。

-r or -replace 这个选项与-i选项的作用相反;此选项将替代表中有相同唯一关键字的记录。

--fields-enclosed- by= char

指定文本文件中数据的记录时以什么括起的, 很多情况下数据以双引号括起。 默认的情况下数据是没有被字符括起的。

--fields-terminated- by=char

指定各个数据的值之间的分隔符,在句号分隔的文件中,分隔符是句号。您可以用此选项指定数据之间的分隔符。默认的分隔符是跳格符(Tab)

--lines-terminated- by=str

此选项指定文本文件中行与行之间数据的分隔字符串或者字符。 默认的情况下mysqlimport以newline为行分隔符。

您可以选择用一个字符串来替代一个单个的字符:一个新行或者一个回车。

mysqlimport命令常用的选项还有-v 显示版本(version), -p 提示输入密码(password)等。

3).例子:导入一个以逗号为分隔符的文件文件中行的记录格式是这样的:

"1", "ORD89876", "1 Dozen Roses", "19991226"

我们的任务是要把这个文件里面的数据导入到数据库Meet_A_Geek中的表格Orders中,我们使用这个命令:

bin/mysqlimport –prl –fields-enclosed-by=" –fields-terminated-by=, Meet_A_Geek Orders.txt

这个命令可能看起来很不爽,不过当你熟悉了之后,这是非常简单的。

第一部分,bin/mysqlimport ,告诉操作系统你要运行的命令是mysql/bin目录下的mysqlimport,选项p是要求输入密码,这样就要求你在改动数据库之前输入密码,操作起来会更安全。我们用了r选项是因为我们想要把表中的唯一关键字与文件记录中有重复唯一关键字的记录替换成文件中的数据。我们表单中的数据不是最新的,需要用文件中的数据去更新,因而就用r这个选项,替代数据库中已经有的记录。l选项的作用是在我们插入数据的时候锁住表,这样就阻止了用户在我们更新表的时候对表进行查询或者更改的操作。

--------------------------------------------------------------------------------

从 MySQL 导入导出大量数据的程序实现方法

http://www.cx66.com/cxgzs/tips/00773.htm

大家一定使用过 phpmyadmin 里面的数据库导入,导出功能,非常方便。但是在实际应用中,我发现如下几个问题:

1、数据库超过一定尺寸,比如6M 这时使用导出一般没问题,可以正确的保存到本机硬盘上面,但是导入则不行!原因是:一般的 PHP.INI 里面设置临时文件/上传文件的大小限制为2M,而phpmyadmin使用了上传的方式,造成失败。

2、导出到硬盘的 .SQL 文件在导回时,经常出现由于某些单引号的问题引起失败,造成导入失败,只能用 mysql等应用程序导入了。

我的数据库已经超过10M,所以必须解决这个问题。我的思路:

导出: 用phpmyadmin 保存数据库/表格结构,用脚本读取数据库内容并保存到文件里面!

导入: 用phpmyadmin 恢复数据库/表格结构,用脚本读取文件,然后保存到库里面!

导出程序如下:调用方法为 ****.php?table=tablename

这个简单的程序目前一次保存一个表格!!每行为一个字段的数据!!

if($table=="")exit();

mysql_connect("localhost","name","password");

mysql_select_db("database");

$result = mysql_query("select * from $table");

if(mysql_num_rows($result) < = 0) exit();

echo "开始转换数据到文本...

";

$handle = fopen("$table.txt","w");

$numfields = mysql_num_fields($result);

fputs($handle,$numfields."

");

for($k=0;$k

{

$msg = mysql_fetch_row($result);

for($i=0;$i< $numfields;$i++)

{

$msg[$i] = str_replace("

","&&php2000mysqlreturn&&",$msg[$i]);

$msg[$i] = str_replace("

" ,"&&php2000mysqlreturn&&",$msg[$i]);

fputs($handle,$msg[$i]."

");

}

fputs($handle,"------- php2000 dump data program V1.0 for MySQL --------

");

}

fclose($handle);

echo "ok";

?>

导入的程序如下:用法同上面!

if($table=="")exit();

mysql_connect("localhost","name","password");

mysql_select_db("database");

$message = file("$table.txt");

echo $numfields = chop($message[0]);

for($k=1;$k

{

$value="";

for ($i=$k;$i< ($k+$numfields-1);$i++)

{

$tmp = str_replace("&&php2000mysqlreturn&&","

",chop($message[$i]));

$value .= "".addslashes($tmp).",";

}

$tmp = str_replace("&&php2000mysqlreturn&&","

",chop($message[$k+$numfields-1]));

$value .= "".$tmp."";

$query = "insert into $table values (".$value.")";

echo mysql_error();

mysql_query($query);

echo $k." ";

}

echo "ok";

?>

使用方法和可能的问题!

1、导入时 file()函数可能会有问题(我的10M的数据没出现问题),可以改为 fopen()然后没次读一行!!

2、导入,导出都需要用 ftp 操作,也就是导出后,用 ftp 把数据转到本机,导入时先用ftp转移数据到服务器!

----------------------------

mysql数据库常用导出导入命令的几个用例

www.yiz.name

================================

几个常用用例:

1.导出整个数据库

mysqldump -u 用户名 -p 数据库名 > 导出的文件名

mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql

2.导出一个表

mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名

mysqldump -u wcnc -p smgp_apps_wcnc users> wcnc_users.sql

3.导出一个数据库结构

mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:wcnc_db.sql

-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop tab

http://www.bkjia.com/PHPjc/508509.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/508509.htmlTechArticle摘自http://qfxy.org.ru/read.php?tid=3071page=e MySQL数据导入导出方法与工具介绍(1) 翻译声明: 本文内容来自Sams Teach Yourself MySQL in 21 Days一书的部分...

相关文章

相关视频

网友评论

文明上网理性发言,请遵守 新闻评论服务协议我要评论

立即提交

专题推荐独孤九贱-php全栈开发教程

全栈 100W+

主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门

玉女心经-web前端开发教程

入门 50W+

主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门

天龙八部-实战开发教程

实战 80W+

主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习

php中文网:公益在线php培训,帮助PHP学习者快速成长!

Copyright 2014-2020 https://www.php.cn/ All Rights Reserved | 苏ICP备2020058653号-1

mysql 导入工具 php_MySQL数据导入导出方法与工具介绍_PHP教程相关推荐

  1. MySQL数据库中导入导出方法以及工具介绍

    MySQL数据库中导入导出方法以及工具介绍 1.MySQLimport的语法介绍: mysqlimport位于mysql/bin目录中,是mysql的一个载入(或者说导入)数据的一个非常有效的工具.这 ...

  2. python excel模板 生成excel表格_python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图...

    python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图 #coding=utf-8 from openpyxl importload_workbookfro ...

  3. rds 数据导入mysql_将数据导入到 Amazon RDS 数据库实例

    常规数据导入性能准则 以下性能准则适用于所有 Amazon RDS 数据导入/导出操作: 使用压缩和多线程并行加载和卸载数据.如果您正在将大量数据并行加载到客户端计算机,请确保在数据加载过程中具有足够 ...

  4. 关于数据可视化的方法和工具介绍

    这一篇给大家全面介绍下关于数据可视化的方法和常用工具. 1. 数据可视化简介 数据可视化,是指用图形的方式来展现数据,从而更加清晰有效地传递信息,主要方法包括图表类型的选择和图表设计的准则. 随着互联 ...

  5. python列表导出_python list格式数据excel导出方法

    如下所示: # _*_ coding:utf-8 _*_ #----------------------------------------------- # import modules #---- ...

  6. 6种上市公司数据的采集方法和工具

    10种AI训练数据采集工具排行榜 6种上市公司数据的采集方法和工具 1.目前常用的6种数据网站 2.如何写Python爬虫: 3.人生第一个 爬虫代码示例: 另外: 6种上市公司数据的采集方法和工具 ...

  7. 数据可视化的方法和工具V1.1

    公众号后台回复"图书",了解更多号主新书内容作者:林骥来源:林骥 最近,我开始修订一些以前发表过的文章. 对我来说,这是一种复习和复盘,从中发现可以改进的地方,并完善自己的知识体系 ...

  8. python列表导出excel_python list格式数据excel导出方法

    如下所示: # _*_ coding:utf-8 _*_ #----------------------------------------------- # import modules #---- ...

  9. mysql 交互命令 导出_MySQL数据导入导出方法与工具(2)

    批处理导入文件,从sql文件导入数据到数据库中 ,批处理是一种非交互式运行mysql程序的方法,如同您在mysql中使用的命令一样,你仍然将使用这些命令. 为了实现批处理,您重定向一个文件到mysql ...

  10. mysql navicat导入bcp_SQL Server数据导入导出工具BCP详解

    BCP是SQL Server中负责导入导出数据的一个命令行工具,它是基于DB-Library的,并且能以并行的方式高效地导入导出大批量的数据.BCP可以将数据库的表或视图直接导出,也能通过SELECT ...

最新文章

  1. windows批量创建用户
  2. phpcms前台注入导致任意文件读取漏洞
  3. Kali Linux 网络扫描秘籍 第三章 端口扫描(一)
  4. python3 验证用户名密码
  5. Odoo与ERP传统软件有什么不同?
  6. 中国自由软件推广先锋的自述,心潮澎湃的一往无前,一定要看!作者:洪峰
  7. 软件工程各种UML总结
  8. inter uhd graphics630显卡驱动_极为全面的!从零开始的!小白都能看懂的!硬件科普#4 显卡选择篇...
  9. 紫光拼音输入法6.7.0.9 论坛测试版发布
  10. 简单html开源游戏案例,基于CreatejsHTML5游戏案例(看你有多色游戏案例)
  11. 100000+人体验过后都说:这TM绝对是最变态的英语学习方法……
  12. 互联网医疗泡沫破灭,一场从线上回归线下的技术圈地运动?
  13. Win10开始菜单打不开怎么办?
  14. MS-DOS基本操作汇总
  15. MapReduce程序中的万能输入FileInputFormat.addInputPaths
  16. 百度上传控件webUPload 的使用
  17. Java中带返回值的线程池Future
  18. Python 线程启动和关闭
  19. 按下鼠标中键跳转新的页面
  20. Matlab中feedback函数的用法

热门文章

  1. MsgBox函数用法小结
  2. Taro Next 发布预览版:同时支持 React / Vue / Nerv
  3. 基于centos7.8的K8安装
  4. [附源码]计算机毕业设计JAVAst音乐网站
  5. C++作业之模拟打牌:小喵钓鱼
  6. winform自定义控件无法显示在工具箱中以及显示但使用时出错的解决办法
  7. 蓝桥杯c语言之小蓝制作门牌
  8. 瞎子摸象——shopnc篇
  9. 雨天的尾巴——LCA+树上差分+动态开点+线段树合并
  10. 高压带电显示器局放检测面板式四合一局放在线监测/带电故障显示/无线测温装置