php实现mysql同步的实现方法


Posted in PHP onOctober 21, 2009

拿到需求之后,发现这两个网站的MYSQL数据库都不能远程访问(安全第一吧)。于是想起了 平时使用的CSV文件批量录入数据。于是
尝试使用CSV导入导出。
导入到处框架如下:
1首先将数据导出成CSV的格式。
建立一文件,放置在中国服务器上:csv.php.其实就是一个导出函数,通过数据库,表名和SQL语句来获得数据。
csv.php

<?php 
/** 
* 输出一个数据库中的表到一个CSV文件中 
* 
* @param string Mysql数据库的主机 
* @param string 数据库名称 
* @param string 数据库中的表名 
* @param string 数据库的连接用户名 
* @param string 数据库的连接密码 
* @param string 数据库的表名 
* @param string 数据库的 
* @param string 错误页面 
* @param string SQL语句 
* 
* @return text 返回CSV格式的内容 
* 
* @access public 
*/ 
function PMA_exportData(host,db,user,pass,filename,table, crlf, error_url, sql_query) { 
what="csv"; 
csv_terminated=" "; 
csv_separator=","; 
csv_enclosed=" "; 
csv_escaped=" "; 
mysql_connect(host, user,pass) or die("不能连接数据库,错误代码如下:" . mysql_error()); 
mysql_select_db(db); 
result = mysql_query(sql_query); 
fields_cnt = mysql_num_fields(result); 
cc=""; 
//fp = fopen(filename, 'w'); 
// 格式化数据 
while (row = mysql_fetch_row(result)) { 
schema_insert = ''; 
for (j = 0; j < fields_cnt; j++) { 
if (!isset(row[j]) || is_null(row[j])) { 
schema_insert .="NULL"; //用什么来替换空值 
} elseif (row[j] == '0' || row[j] != '') { 
// loic1 :用引号包含字段值 
if (csv_enclosed == '') { 
schema_insert .= row[j]; 
} else { 
schema_insert .= csv_enclosed 
. str_replace(csv_enclosed, csv_escaped . csv_enclosed, row[j]) 
. csv_enclosed; 
} 
} else { 
schema_insert .= ''; 
} 
if (j < fields_cnt-1) { 
schema_insert .= csv_separator; 
} 
} // end for 
// fwrite(fp,schema_insert . csv_terminated); 
cc.=schema_insert . csv_terminated; 
} // end while 
mysql_free_result(result); 
// fclose(fp); 
return cc; 
} 
?>

2.将CSV格式的内容导入到表中
在美国服务器上建立个导入的文件,放置:import.php ,代码如下:
<?php 
/** 
* 从一个上传的文件中将数据导入到一个表中 
* 
* @param string Mysql数据库的主机 
* @param string 数据库名称 
* @param string 数据库中的表名 
* @param string 数据库的连接用户名 
* @param string 数据库的连接密码 
* @param string 数据库的表名 
* 
* @return bool 是否执行成功 
* 
* @access public 
*/ 
function uploadFileOfCsv(host,db,user,pass,table,content){ 
mysql_connect(host, user,pass) or die("不能连接数据库,错误代码如下:" . mysql_error()); 
mysql_select_db(db); 
result = mysql_query("select * from table"); 
fields_cnt = mysql_num_fields(result); 
test2=array(array()); 
rownum=0; 
log("提取的数据如下:<br>".content); 
fd1 = fopen ("C:test.csv",'a'); 
fwrite(fd1,content); 
fclose(fd1); 
fp = fopen("C:test.csv", "r"); 
while (buffer = fgets(fp,4096)) 
{ 
i++; 
tmp_arr = explode(",",buffer); 
if(trim(tmp_arr[0]) == ""){ 
echo "<script language='javascript'>"; 
echo "alert('第".i."行的ID空,请检查!');"; 
echo "location.href=document.referrer;"; 
echo "</script>"; 
exit; 
} 
query = "INSERT INTO db.table"; 
query .=" values ( "; 
for(q=0;q<fields_cnt;q++){ 
if(q==fields_cnt-1){ 
tmp=tmp_arr[q]; 
query.="'tmp');"; 
}else{ 
tmp=tmp_arr[q]; 
query.="'tmp',"; 
} 
}//end for(q=0; 
log2(query); 
mysql_query(query); 
} 
fclose(fp); 
return "OK"; 
unlink("C:test.csv"); 
} 
function log2(event = null){ 
//global db; 
// global login; 
if(LOG_ENABLED){ 
now = date("Y-M-d H:i:s"); 
fd = fopen ("C:log.html",'a'); 
log = now." "._SERVER["REMOTE_ADDR"] ." - event <br>"; 
fwrite(fd,log); 
fclose(fd); 
} 
} 
?>

3调用函数执行导出
在中国服务器上再建立一个 文件:test_export.php,调用前面的csv.php的函数,然后将数据转成CSV,然后临时存到一个表单的
textera中,注意表单提交的位置:
<?php 
require_once("csv.php"); 
host="localhost"; 
db="project"; 
user="root"; 
pass=""; 
//导出tb_contact表的数据为csv文件 
filename = 'file4.csv'; 
cc=PMA_exportData( host,db,user,pass, filename,"tb_project_dvp", "", "test.php", "select * from tb_project_dvp") ; 
handle = fopen(filename, "rb"); 
contents = fread(handle, filesize (filename)); 
fclose(handle); 
?> 
<form id="form1" name="form1" method="post" action="http://美国网站的地址/test2.php"> 
<p> 
<textarea name="textarea" cols="180" rows="30"><?php echo cc?></textarea> 
<input type="hidden" name="action" value="1"/> 
</p> 
<p> 
<input type="submit" name="Submit" value="提交"> 
</p> 
</form>

再在美国服务器上防置如下文件用于接受上传上来的数据,文件名为 test_import.php:
<?php 
require_once("csv.php"); 
require_once("import.php"); 
host="localhost"; 
db="wintopweb"; 
user="root"; 
pass=""; 
if(_POST['action']=="1"){ 
content=_POST['textarea']; 
echo uploadFileOfCsv(host,db,user,pass,"tb_project_dvp",content); 
} 
?>

最后 利用Windows-xp/nt/03 控制面版中自带 任务计划,调度执行中国服务器test_export.php文件即可
PHP 相关文章推荐
色色整理的PHP面试题集锦
Mar 08 PHP
PHP优于Node.js的五大理由分享
Sep 15 PHP
ThinkPHP模板比较标签用法详解
Jun 30 PHP
PHP中set error handler函数用法小结
Nov 11 PHP
详解WordPress中简码格式标签编写的基本方法
Dec 22 PHP
Zend Framework实现多服务器共享SESSION数据的方法
Mar 22 PHP
php中分页及SqlHelper类用法实例
Jan 12 PHP
PHP实现的DES加密解密封装类完整实例
Apr 29 PHP
Mac系统完美安装PHP7详细教程
Jun 06 PHP
PHP实现对图片的反色处理功能【测试可用】
Feb 01 PHP
php中文语义分析实现方法示例
Sep 28 PHP
PHP设计模式(九)外观模式Facade实例详解【结构型】
May 02 PHP
php 魔术方法使用说明
Oct 20 #PHP
关于Appserv无法打开localhost问题的解决方法
Oct 16 #PHP
php foreach、while性能比较
Oct 15 #PHP
php侧拉菜单 漂亮,可以向右或者向左展开,支持FF,IE
Oct 15 #PHP
php 数学运算验证码实现代码
Oct 11 #PHP
用mysql触发器自动更新memcache的实现代码
Oct 11 #PHP
基于OpenCV的PHP图像人脸识别技术
Oct 11 #PHP
You might like
《PHP编程最快明白》第四讲:日期、表单接收、session、cookie
2010/11/01 PHP
linux中cd命令使用详解
2015/01/08 PHP
PHP入门教程之PHP操作MySQL的方法分析
2016/09/11 PHP
PHP云打印类完整示例
2016/10/15 PHP
Laravel 修改验证异常的响应格式实例代码详解
2020/05/25 PHP
基于jQuery的弹出框插件
2012/03/18 Javascript
在Mac OS下使用Node.js的简单教程
2015/06/24 Javascript
轻松实现javascript数据双向绑定
2015/11/11 Javascript
js与jquery正则验证电子邮箱、手机号、邮政编码的方法
2016/07/04 Javascript
打造自己的jQuery插件入门教程
2016/09/23 Javascript
tablesorter.js表格排序使用方法(支持中文排序)
2017/02/10 Javascript
Angular中实现树形结构视图实例代码
2017/05/05 Javascript
node.js中fs.stat与fs.fstat的区别详解
2017/06/01 Javascript
深入研究jQuery图片懒加载 lazyload.js使用方法
2017/08/16 jQuery
AngularJS select设置默认值的实现方法
2017/08/25 Javascript
react配合antd组件实现的管理系统示例代码
2018/04/24 Javascript
jQuery实现ajax回调函数带入参数的方法示例
2018/06/26 jQuery
Egg.js 中 AJax 上传文件获取参数的方法
2018/10/10 Javascript
JS 音频可视化插件Wavesurfer.js的使用教程
2018/10/31 Javascript
vue中通过使用$attrs实现组件之间的数据传递功能
2019/09/01 Javascript
js实现带积分弹球小游戏
2020/07/21 Javascript
Python Web框架Pylons中使用MongoDB的例子
2013/12/03 Python
Python不规范的日期字符串处理类
2014/06/10 Python
python ddt实现数据驱动
2018/03/14 Python
解决tensorflow测试模型时NotFoundError错误的问题
2018/07/27 Python
python实现一组典型数据格式转换
2018/12/15 Python
用Python将结果保存为xlsx的方法
2019/01/28 Python
python的命名规则知识点总结
2019/10/04 Python
python 函数嵌套及多函数共同运行知识点讲解
2020/03/03 Python
使用python求斐波那契数列中第n个数的值示例代码
2020/07/26 Python
为什么UNION ALL比UNION快
2016/03/17 面试题
年度优秀员工获奖感言
2014/08/15 职场文书
2015年学校政教工作总结
2015/07/20 职场文书
课题研究阶段性总结
2015/08/13 职场文书
高中团支书竞选稿
2015/11/21 职场文书
maven 解包依赖项中的文件的解决方法
2022/07/15 Java/Android