
从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转移数据到服务器!
- 跟着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必知的事情 装机之必备软件大行动
