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 相关文章推荐
CakePHP去除默认显示的标题及图标的方法
Oct 22 PHP
如何在symfony中导出为CSV文件中的数据
Oct 06 PHP
解析:通过php socket并借助telnet实现简单的聊天程序
Jun 18 PHP
Win7下手动安装apache2.2、php5.4笔记
Apr 03 PHP
PHP上传图片时判断上传文件是否为可用图片的方法
Oct 20 PHP
ThinkPHP框架表单验证操作方法
Jul 19 PHP
thinkPHP框架动态配置用法实例分析
Jun 14 PHP
Discuz不使用插件实现简单的打赏功能
Mar 21 PHP
零基础php编程好学吗
Oct 11 PHP
基于laravel缓冲cache的用法详解
Oct 23 PHP
PHP连续签到功能实现方法详解
Dec 04 PHP
PHP的垃圾回收机制代码实例讲解
Feb 27 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无法访问远程mysql的问题分析及解决
2013/05/16 PHP
javascript写的一个链表实现代码
2009/10/25 Javascript
JavaScript实现复制功能各浏览器支持情况实测
2013/07/18 Javascript
JS判断字符串包含的方法
2015/05/05 Javascript
jQuery中slidedown与slideup方法用法示例
2016/09/16 Javascript
让html元素随浏览器的大小自适应垂直居中的实现方法
2016/10/12 Javascript
JavaScript正则表达式替换字符串中图片地址(img src)的方法
2017/01/13 Javascript
vue 2.0路由之路由嵌套示例详解
2017/05/08 Javascript
vue快捷键与基础指令详解
2017/06/01 Javascript
JS中正则表达式要注意lastIndex属性
2017/08/08 Javascript
JS实现常见的查找、排序、去重算法示例
2018/05/21 Javascript
vue2.0+vuex+localStorage代办事项应用实现详解
2018/05/31 Javascript
JavaScript中展开运算符及应用的实例代码
2021/01/14 Javascript
rhythmbox中文名乱码问题解决方法
2008/09/06 Python
Python算法应用实战之栈详解
2017/02/04 Python
python对列进行平移变换的方法(shift)
2019/01/10 Python
详解python函数的闭包问题(内部函数与外部函数详述)
2019/05/17 Python
python PyAutoGUI 模拟鼠标键盘操作和截屏功能
2019/08/04 Python
python标记语句块使用方法总结
2019/08/05 Python
python中使用while循环的实例
2019/08/05 Python
浅谈图像处理中掩膜(mask)的意义
2020/02/19 Python
Visual Studio code 配置Python开发环境
2020/09/11 Python
python 监控服务器是否有人远程登录(详细思路+代码)
2020/12/18 Python
CSS3与动画有关的属性transition、animation、transform对比(史上最全版)
2017/08/18 HTML / CSS
美国照明、家居装饰和家具购物网站:Bellacor
2017/09/20 全球购物
匈牙利最大的健身制造商和销售商:inSPORTline
2018/10/30 全球购物
用C#语言写出与SQLSERVER访问时的具体过程
2013/04/16 面试题
入党申请人的自我鉴定
2013/12/01 职场文书
出纳员岗位职责
2014/03/13 职场文书
群众路线教育实践活动学习笔记内容
2014/11/06 职场文书
2014年流动人口工作总结
2014/11/26 职场文书
支教个人总结
2015/03/04 职场文书
找规律教学反思
2016/02/23 职场文书
学生早退检讨书(范文)
2019/08/19 职场文书
python将图片转为矢量图的方法步骤
2021/03/30 Python
Java 死锁解决方案
2022/05/11 Java/Android