百独托管7500 紫田网络超高转化播放器收cps[推荐]速盾CDN 免实名免备防屏蔽阿里云 爆款特卖9.9元封顶提升alexa、IP流量7Q5团队
【腾讯云】中小企福利专场【腾讯云】多款产品1折起高防 随时退换 好耶数据小飞国外网赚带你月入万元炎黄网络4H4G10M 99每月
香港带宽CN2/美国站群优惠中客数据中心 服务器租用联盟系统移动广告平台 中易企业专场腾讯云服务器2.5折九九数据 工信部正规资质
腾讯云新用户大礼包代金券高价收cpa注册量高价展示【腾讯云】2核2G/9.93起租服务器找45互联 随时退换阿里云 短信服务 验证秒达

[闲聊畅谈] 问点技术性的问题,PHP7下MYSQL备份 [复制链接]
查看:2196 | 回复:10

落伍网友
落伍网友  发表于 2021-8-25 11:42:57 |阅读模式 来自 中国广东深圳
用着10年的老程序,最近升级了PHP7一下各种报错全来了。自己百度解决了大部份问题。

备份表的自己解决了,可是备份内容的实在找不到方法了,文件内容如下,各位大大帮看下

  1. public function list_fields($dbname,$tbname){return  mysqli_list_fields($dbname,$tbname,$this->link_id);}
复制代码


  1. if(!IsNum($size))
  2.         $size=1024;
  3.         $bakStr='';
  4.         $tabelresult=$db->list_tables(cd_sqldbname);
  5.         if($tabelresult){
  6.                 while($tabelrow=mysql_fetch_row($tabelresult)){
  7.                         $ycms_ID=explode("_",$tabelrow[0]);
  8.                         if($ycms_ID[0]==ReplaceStr(cd_tablename, "_", "")){
  9.                                 $intable="INSERT INTO `$tabelrow[0]` VALUES(";
  10.                                 $fieldresult = $db->list_fields(cd_sqldbname, $tabelrow[0]);
  11.                                 $i=0;
  12.                                 if($fieldresult) {
  13.                                         //分析表里的字段信息
  14.                                         while($fieldrow=mysql_fetch_field($fieldresult)){
  15.                                                 $fs[$i]=trim($fieldrow->name);
  16.                                                 $i++;
  17.                                         }
  18.                                         $fsd=$i-1;
  19.                                         ////读取表的内容
  20.                                         $sql="select * from `$tabelrow[0]`";
  21.                                         $result=$db->getAll($sql);
  22.                                         for($j=0;$j<count($result);$j++){
  23.                                                 $line=$intable;
  24.                                                 for($k=0; $k<=$fsd; $k++){
  25.                                                         if($k<$fsd) {
  26.                                                                 $line.="'".mysql_escape_string($result[$j][$fs[$k]])."',";
  27.                                                         }else{
  28.                                                                 $line.="'".mysql_escape_string($result[$j][$fs[$k]])."');\r\n";
  29.                                                         }
  30.                                                 }
  31.                                                 $bakStr.=$line;
  32.                                                 if(strlen($bakStr)>$size*1024){
  33.                                                         $a=$a+1;
  34.                                                         $b=$b+1;
  35.                                                         $bkfile="../backup/".date('Ymd-H')."/tables_datas_".substr(md5(time().mt_rand(1000,5000)),0,16).".txt";
  36.                                                         $fp=fopen($bkfile, "w");
  37.                                                         fwrite($fp, $bakStr);
  38.                                                         fclose($fp);
  39.                                                         echo "&nbsp;<font style="font-size:10pt;">数据库:<font color=red>../backup/".date('Ymd-H')."/".rand(1000,5000)."".rand(1000,5000)."".rand(1000,5000).".txt</font> 文件备份成功...</font></font><br/>";
  40.                                                         $bakStr='';
  41.                                                 }
  42.                                         }
  43.                                 }
  44.                         }
  45.                 }
  46.                 if(!empty($bakStr) && strlen($bakStr)<$size*1024){
  47.                         $bkfile="../backup/".date('Ymd-H')."/tables_datas_".substr(md5(time().mt_rand(1000,5000)),0,16).".txt";
  48.                         $fp=fopen($bkfile,"w");
  49.                         fwrite($fp,$bakStr);
  50.                         fwrite(fopen("../backup/".date('Ymd-H')."/Atime.txt", "wb"),"".date('Y-m-d H:i:s')." / ".$_COOKIE['CD_AdminUserName']."");
  51.                         fwrite(fopen("../tools/bftime.txt", "wb"),"".date('Y-m-d H:i:s')."");
  52.                         if($b){$backupsize=formatsize($b*1048576);}else{$backupsize='1MB';}
  53.                         exit("<br/><br/>&nbsp;<font style="font-size:10pt;"><b>恭喜您,数据库已全部备份完毕!</b></font>&nbsp;<font style="font-size:10pt;"><b>备份".$a."个文件,占用空间:".$backupsize."</b></font><script language='javascript'>alert('恭喜您,数据库已全部备份完毕!共备份".$a."个文件,占用空间:".$backupsize."');top.frames['main'].location.reload();</script>");
  54.                         fclose($fp);
  55.                 }
  56.         }
复制代码
回复

使用道具 举报

324

主题

1826

帖子

1万

积分

落伍者(四季发财)

广州BGP双线5M独享特价!

Rank: 4

贡献
85
鲜花
73
注册时间
2010-2-26

落伍手机绑定

发表于 2021-8-25 12:15:04 | 显示全部楼层 来自 中国湖南娄底
整这么麻烦干嘛,直接mysqldump不香吗
回复 支持 反对

使用道具 举报

9742

主题

5万

帖子

7845

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
3987
鲜花
65
注册时间
2007-12-29

落伍手机绑定

发表于 2021-8-26 00:06:27 | 显示全部楼层 来自 中国湖南长沙
希望以后用得上
免费扫高权重域名:加落伍创业干货群52385364
数字创业资质办理:天津盛世创举
回复 支持 反对

使用道具 举报

头像被屏蔽

511

主题

1万

帖子

1万

积分

落伍者(四季发财)

Rank: 4

贡献
3052
鲜花
80
注册时间
2007-10-25
发表于 2021-8-26 09:27:42 | 显示全部楼层 来自 中国江苏无锡
提示: 作者被禁止或删除 内容自动屏蔽
签名被屏蔽
回复 支持 反对

使用道具 举报

1099

主题

9551

帖子

9451

积分

落伍管理

正牌猪头,别无分店

Rank: 12Rank: 12Rank: 12

贡献
7068
鲜花
762
注册时间
2004-5-12

落伍手机绑定

发表于 2021-8-26 13:00:12 | 显示全部楼层 来自 中国广东佛山
pdo封装到家,推荐使用
装B之人必有傻B之处。
回复 支持 反对

使用道具 举报

98

主题

4124

帖子

3863

积分

落伍者(两全齐美)

Rank: 2

贡献
175
鲜花
16
注册时间
2015-3-12
发表于 2021-8-26 19:07:26 来自落伍手机版 | 显示全部楼层 来自 中国浙江
备份个啥?mysql停止,直接打包
回复 支持 反对

使用道具 举报

217

主题

1万

帖子

4628

积分

落伍者(两全齐美)

Rank: 2

贡献
4484
鲜花
2
注册时间
2006-4-26

落伍手机绑定

发表于 2021-8-26 21:46:47 | 显示全部楼层 来自 中国河北石家庄
是虚拟机就用免费的帝国备份王,分卷备份,无论多大表都能备份,不要自己去写php程序

如果是vps或独立服务器,可以mysqldump
士为知己者死,女为悦己者容
回复 支持 反对

使用道具 举报

218

主题

3万

帖子

3万

积分

落伍者(四季发财)

Rank: 4

贡献
947
鲜花
28
注册时间
2002-6-5

落伍手机绑定

发表于 2021-8-27 00:40:20 | 显示全部楼层 来自 中国广西百色
lichail 发表于 2021-8-26 21:46
是虚拟机就用免费的帝国备份王,分卷备份,无论多大表都能备份,不要自己去写php程序

如果是vps或独立服 ...

收藏一下
回复 支持 反对

使用道具 举报

255

主题

1万

帖子

1万

积分

落伍者(四季发财)

小林子

Rank: 4

贡献
3626
鲜花
53
注册时间
2006-10-15

QQ绑定落伍手机绑定

发表于 2021-8-27 09:53:48 | 显示全部楼层 来自 中国福建三明
lichail 发表于 2021-8-26 21:46
是虚拟机就用免费的帝国备份王,分卷备份,无论多大表都能备份,不要自己去写php程序

如果是vps或独立服 ...

帝国备份王是不是不兼容php7?安装后一大堆报错
云南古树白茶 ,V:linchaye
回复 支持 反对

使用道具 举报

217

主题

1万

帖子

4628

积分

落伍者(两全齐美)

Rank: 2

贡献
4484
鲜花
2
注册时间
2006-4-26

落伍手机绑定

发表于 2021-8-29 19:47:54 | 显示全部楼层 来自 中国河北石家庄
我用的php7.1.4没问题,官方下载:
http://www.phome.net/product/Ebak.html
士为知己者死,女为悦己者容
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

论坛客服/商务合作/投诉举报:2171544 (QQ)
落伍者创建于2001/03/14,本站内容均为会员发表,并不代表落伍立场!
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论!
落伍官方微信:2030286 邮箱:(djfsys@gmail.com|tech@im286.com)
© 2001-2014

浙公网安备 33060302000191号

浙ICP备11034705号 BBS专项电子公告通信管[2010]226号

  落伍法律顾问: ITlaw-庄毅雄

手机版|找回帐号|不能发帖?|Archiver|落伍者

GMT+8, 2024-11-26 17:28 , Processed in 0.083089 second(s), 31 queries , Gzip On.

返回顶部