PHP 使用文件方式导入导出整个MYSQL数据库的实现方法
PHP mysql以文件形式导入导出整个数据库,感兴趣的小伙伴,下面一起跟随512笔记的小编罗X来看看吧。
经测试代码如下:
<?php/** * 文件方式导入导出整个MYSQL数据库 * * @param 使用时一定要注意是否是处于导入状态,如果是导入操作,一定要先备份数据库,否则数据会被清空。。 * @author 512笔记 www.512pic.com **//* 导出SELECT * INTO OUTFILE 'c:/name.txt'FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '\''LINES TERMINATED BY '\n'FROM zones;导入LOAD DATA INFILE 'c:/name.txt' INTO TABLE zones FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '\''LINES TERMINATED BY '\n';*/ set_time_limit(0);define(HOST,'127.0.0.1');define(USER,'root');define(PWD,'');define(DBNAME,'test');define(DIR,'E:/www/mysql_data/');//0为导入 1为导出 2为修复 define(OPERATION,1);mysql_connect(HOST,USER,PWD) ordie("Could not connect: " . mysql_error());mysql_select_db(DBNAME) ordie("Could not select db: " . mysql_error());$result = mysql_query("show tables");if(!is_dir(DIR)){ die('Folder does not exist');}if(OPERATION==0){ //前提:需要先前导入表结构 //导出命令:mysqldump -u root -p -d test>test.sql while ($row = mysql_fetch_array($result, MYSQL_NUM)) { $fileName=DIR.$row[0].".txt"; if(file_exists($fileName)){ //delete truncate $querySql='TRUNCATE TABLE `'.$row[0].'`'; mysql_query($querySql) or die("Could not truncate table: ". $querySql . mysql_error()); $querySql = "LOAD DATA INFILE '".$fileName."' INTO TABLE `".$row[0]."` FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '\'' LINES TERMINATED BY '\n'"; mysql_query($querySql) or die("Could not insert into table: ". $querySql . mysql_error()); echo 'insert into table '.$row[0].' success.<br/>'; }else{ echo 'Not insert into table '.$row[0].'<br/>'; } } echo "The task is finished";}else if(OPERATION==1){ if (is_writable(DIR)) { while ($row = mysql_fetch_array($result, MYSQL_NUM)) { $fileName=DIR.$row[0].".txt"; if(file_exists($fileName)){ unlink($fileName); } $querySql = "SELECT * INTO OUTFILE '".$fileName."' FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '\'' LINES TERMINATED BY '\n' FROM `".$row[0]."`"; mysql_query($querySql) or die("Could not dump table: ". $querySql . mysql_error()); echo 'dump table '.$row[0].' success.<br/>'; } echo "The task is finished"; }else{ echo 'Folder '.DIR.' can not writeable'; }}else if(OPERATION==2){ while ($row = mysql_fetch_array($result, MYSQL_NUM)) { $fileName=DIR.$row[0].".txt"; if(file_exists($fileName)){ unlink($fileName); } $querySql = "REPAIR TABLE `$row[0]`"; mysql_query($querySql) or die("Could not repair table: ". $querySql . mysql_error()); echo 'repair table '.$row[0].' success.<br/>'; }}mysql_free_result($result);mysql_close();?>/*** 来自512笔记(www.512pic.com) ***/
本文来自:http://www.512pic.com/173/202-0.html
注:关于PHP 使用文件方式导入导出整个MYSQL数据库的实现方法的内容就先介绍到这里,更多相关文章的可以留意512笔记的其他信息。
关键词:数据库
赞 (0)