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数组函数序列 之shuffle()和array_rand() 随机函数使用介绍
Oct 29 PHP
php格式化日期和时间格式化示例分享
Feb 24 PHP
PhpDocumentor 2安装以及生成API文档的方法
May 21 PHP
smarty中post用法实例
Nov 28 PHP
浅析THINKPHP的addAll支持的最大数据量
Feb 03 PHP
php基于curl实现的股票信息查询类实例
Nov 11 PHP
php实现的读取CSV文件函数示例
Feb 07 PHP
PHP 7安装调试工具Xdebug扩展的方法教程
Jun 17 PHP
PHP实现实时生成并下载超大数据量的EXCEL文件详解
Oct 23 PHP
PHP实现防止表单重复提交功能【基于token验证】
May 24 PHP
PHP使用phpunit进行单元测试示例
Sep 23 PHP
解决laravel查询构造器中的别名问题
Oct 17 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
星际中一些鲜为人知的详细资料
2020/03/04 星际争霸
php操作sqlserver关于时间日期读取的小小见解
2009/11/29 PHP
ThinkPHP使用smarty模板引擎的方法
2014/07/01 PHP
详解WordPress中用于更新和获取用户选项数据的PHP函数
2016/03/08 PHP
(推荐一个超好的JS函数库)S.Sams Lifexperience ScriptClassLib
2007/04/29 Javascript
JAVASCRIPT style 中visibility和display之间的区别
2010/01/22 Javascript
jquery遍历checkbox介绍
2014/02/21 Javascript
Vuejs第六篇之Vuejs与form元素实例解析
2016/09/05 Javascript
request请求获取参数的实现方法(post和get两种方式)
2016/09/27 Javascript
基于KO+BootStrap+MVC实现的分页控件代码分享
2016/11/07 Javascript
浅谈Node.js:Buffer模块
2016/12/05 Javascript
javascript 显示全局变量与隐式全局变量的区别
2017/02/09 Javascript
微信小程序实现城市列表选择
2018/06/05 Javascript
解决vue中使用proxy配置不同端口和ip接口问题
2019/08/14 Javascript
[46:00]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#4EG VS Fnatic第一局
2016/03/03 DOTA
[55:03]完美世界DOTA2联赛PWL S2 LBZS vs FTD.C 第二场 11.20
2020/11/20 DOTA
python处理按钮消息的实例详解
2017/07/11 Python
Python实现MySQL操作的方法小结【安装,连接,增删改查等】
2017/07/12 Python
python+matplotlib绘制简单的海豚(顶点和节点的操作)
2018/01/02 Python
python实现大战外星人小游戏实例代码
2019/12/26 Python
python opencv根据颜色进行目标检测的方法示例
2020/01/15 Python
Django单元测试中Fixtures用法详解
2020/02/25 Python
pyqt5 QlistView列表显示的实现示例
2020/03/24 Python
TensorFlow Autodiff自动微分详解
2020/07/06 Python
Django配置跨域并开发测试接口
2020/11/04 Python
python3爬虫中引用Queue的实例讲解
2020/11/24 Python
python 实现一个简单的线性回归案例
2020/12/17 Python
python中numpy.empty()函数实例讲解
2021/02/05 Python
定义css设备类型-Media Queries图表简介及使用方法
2013/01/21 HTML / CSS
为什么会有内存对齐
2016/10/10 面试题
关于递归的一道.NET面试题
2013/05/12 面试题
大一工商管理职业生涯规划:有梦最美,行动相随
2014/09/18 职场文书
文明单位创建材料
2014/12/24 职场文书
干部考察材料范文
2014/12/24 职场文书
2016年清明节红领巾广播稿
2015/12/17 职场文书
导游词书写之黄山
2019/08/06 职场文书