博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【奇葩的需求】对整个数据库里的所有表的所有字段的数据操作
阅读量:6039 次
发布时间:2019-06-20

本文共 1456 字,大约阅读时间需要 4 分钟。

    哎,因为图片服务器的网址变了,所以让把数据库里所有表所有字段的数据里的旧网址替换成新网址,所以就只能写了这么一个代码,貌似效率还不错,20多W的数据量,只用了13秒,好的代码不需要太多的文字来解释

getTables(); foreach($tableList as $k=>$v){ //如果没有数据则直接执行 if($this->getDataList($v)){ //获取表字段 $fieldList=$this->getFieldInfo($v); $list=$this->db_replace($v,$fieldList); dump($list); } } } private function getTables(){ $model=D('Api'); $tableList=$model->getTables(); //获取所有表名 //处理表名称 foreach($tableList as $k=>$v){ if(substr($v,0,strlen(C('DB_PREFIX')))!==C('DB_PREFIX')) unset($tableList[$k]); else $tableList[$k]=str_replace(C('DB_PREFIX'),'',$v); } return $tableList; } //获取字段信息 private function getFieldInfo($table){ $model=D($table); $list=$model->getDbFields(); return $list; } //查询表中是否有数据 private function getDataList($table){ $model=D($table); $list=$model->select(); if($list) return true; else return false; } //执行替换 private function db_replace($table,$field){ $tableName=C('DB_PREFIX').$table; $field=$this->db_filter($field); if(!empty($field)){ foreach($field as $k=>$v){ $sql="UPDATE `$tableName` SET `$v` = REPLACE ( `$v`, '$this->old_str', '$this->new_str' ); "; if(M()->execute($sql)) $ok[]='替换完成,替换表为.'.$tableName.'|替换字段为'.$v.'
'; } } return $ok; } //字段过滤 private function db_filter($field){ $in=array('id','name','title','token','wecha_id','pid','level','uid'); foreach($field as $k=>$v){ if(in_array($v,$in)){ unset($field[$k]); } } return $field; }}


footer.jpg

转载地址:http://iwrhx.baihongyu.com/

你可能感兴趣的文章
ios之UISlider
查看>>
短信验证流程
查看>>
php 使用htmlspecialchars() 和strip_tags函数过滤HTML标签的区别
查看>>
OpenCV Error: Assertion failed (data0.dims <= 2 && type == 5 && K > 0) in cv::kmeans
查看>>
python string 之 format
查看>>
树形DP 复习
查看>>
Vuex随笔
查看>>
crontab 不执行
查看>>
避免用for循环写数据
查看>>
Dijkstra(变形) POJ 1797 Heavy Transportation
查看>>
关于Webpack详述系列文章 (第三篇)
查看>>
关于Webpack详述系列文章 (第四篇)
查看>>
分布式系统的面试题15
查看>>
个人代码库の创建快捷方式
查看>>
由strcat函数引发的C语言中数组和指针问题的思考
查看>>
无锁编程
查看>>
如何在loadrunner中做关联
查看>>
二叉树的六种遍历方法汇总(转)
查看>>
用wxpython制作可以用于 特征筛选gui程序
查看>>
【转载】 [你必须知道的.NET]目录导航
查看>>