注册通行证 用户名 密码
  • 文章投稿
  • 博客
  • 论坛
  • 设为首页
  • 加入收藏
jztop.com网络技术
  • 首页
  • | iT新闻
  • | 操作系统
  • | 组网建网
  • | 网络安全
  • | 程序开发
  • | 办公一族
  • | 工具软件
  • | 网页制作
  • | 多媒体制作
  • | 网吧技术
  • | 服务器
  • | 专题教程
Vista | 软件评测 | 系统备份 | 优化 | 进程 | 聊天 | 病毒 | Linux | 黑客 | 防火墙 | 数据库 | Web开发 | Java | Word | 游戏 | 32位开发 | 移动开发
当前位置:首页 > 程序开发 > 数据库 > MySql 内容正文:从MySQL导入导出大量数据的程序实现方法

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

发布时间:2006-06-12 23:50:31 来源:友佳学院(整理) 网友评论 0 条

大家一定使用过 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./"/r/n/");
for($k=0;$k< mysql_num_rows($result);$k++)
{
$msg = mysql_fetch_row($result);
for($i=0;$i< $numfields;$i++)
{
$msg[$i] = str_replace(/"/r/n/",/"&&php2000mysqlreturn&&/",$msg[$i]);
$msg[$i] = str_replace(/"/n/" ,/"&&php2000mysqlreturn&&/",$msg[$i]);
fputs($handle,$msg[$i]./"/r/n/");
}
fputs($handle,/"------- php2000 dump data program V1.0 for MySQL --------/r/n/");
}
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< count($message);$k+=($numfields+1))
{
$value=/"/";
for ($i=$k;$i< ($k+$numfields-1);$i++)
{
$tmp = str_replace(/"&&php2000mysqlreturn&&/",/"/r/n/",chop($message[$i]));
$value .= /"/'/".addslashes($tmp)./"/',/";
}
$tmp = str_replace(/"&&php2000mysqlreturn&&/",/"/r/n/",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导出XLS数据库工具(跨平台)
  • 从MySQL导入导出大量数据的程序实现方法
【评论】【收藏本文】【打印】【关闭】
上一篇文章:Linux应用集成MySQL数据库访问技巧
下一篇文章:Mysql中的临时表使用方法讲解
讨论区
查看
已有 0 位对此新闻感兴趣的网友发表了看法
匿名发表
注册通行证 登陆
图文阅读推荐
推荐阅讯
  • 跟着lanche学MySQL
  • MySQL 5.0 新特性教程 存储过程:第四讲
  • MYSQL服务维护及应用设计笔记
  • MYSQL出错代码列表
  • Mysql日期和时间函数
  • Debian下Mysql实践
  • MYSQL出错代码及出错信息对照
  • MySQL3.23.31之前版本的安全漏洞
  • 从MySQL到ORACLE程序迁移的注意事项
  • MySQL和Access的区别
阅读排行
  • 1.完整图解 Tomcat 5.0.28 安装笔记
  • 2.Tomcat+SQL Server2000连接池配置
  • 3.MySQL 5.015官网下载地址
  • 4.MySQL Client下载列表
  • 5.MySQL数据库如何实现双机热备的配置
  • 6.JDBC连接SQL2000详细流程
  • 7.MySQL for Linux (x86, glibc-2.2, static,
  • 8.MySQL数据库的多表操作和备份处理
  • 9.一个简便的MySql数据库备份的方法
  • 10.MySQL数据查询器下载列表
专题教程
  • 大话G游 专题:手机病毒揭密
  • ARP攻击防范与解决方案 路由故障处理手册
  • Picasa中文版_Picasa教程 专题:清除流氓软件
  • Firefox专题 seo搜索引擎优化专区
  • 重装Windows必知的事情 装机之必备软件大行动
病毒专杀栏
  • 杀毒软件反被病毒杀 连"救命"都不能喊
  • 金山ARP防火墙
  • 还原卡神话破灭“机器狗”病毒来势汹汹
  • cctv经济半小时:你的手机现在安全吗?
  • 新挂马方式开始流行 ARP挂马称雄局域网
  • 木马和病毒清除的通用解法
  • IP地址不再冲突 查找ARP攻击者元凶
  • 教你几招识别和防御Web网页木马
  • 分析:封杀BT只是暂时的止痛药
  • QQ爆危险漏洞,“QQ游戏邀请大盗”邀请你玩病
关于我们 | 诚聘英才 | 联系我们 | 版权声明 | 网站大事 | 网站地图 | 意见建议
CopyRight 2005-2007 Jztop.Com 版权所有 未经许可 请勿转载