mysql全库搜索关键字_PHP 检索整个数据库 所有表 所有字段 包含某个关键字

论坛 期权论坛 编程之家     
选择匿名的用户   2021-5-28 18:48   45   0

场景

刚刚在项目中用到了删除包含某个关键字内容,需要检索整个数据库的所有表、所有字段的值。这里记录一下PHP的方法。

思路

分析数据库结构,然后将所有varchar类型的字段取出来

用 or 语句拼接所有可用字段,并搜索关键词

打印出对应的表的对应字段

PHP代码实例function search_all_db( $search_key ){

$tables = db_sql_query("show tables");

foreach($tables as $t){

sort($t);

$all_tables[] = $t[0];

}

foreach($all_tables as $t){

$columns = db_sql_query("show columns from $t");

$columns_arr = array();

foreach($columns as $c){

if(substr($c['Type'], 0, 7) != 'varchar'){continue;}

$columns_arr[] = '`' . $c['Field'] . '`' . " like '%$search_key%'";

}

if(empty($columns_arr)){continue;}

$sql = "SELECT * from $t where " . implode(' or ', $columns_arr);

$rs = db_sql_query($sql);

//echo $sql . "";

if($rs){

$and_arr = array();

foreach($columns_arr as $c){

$sql = "SELECT * from $t where $c";

$s = db_sql_query($sql);

if($s){

$and_arr[] = str_replace(' like ', ' not like ', $c);

//echo $sql . "";

}

}

if(!empty($and_arr)){

$sql = "SELECT * from $t where " . implode(' and ', $and_arr);

$s = db_sql_query($sql);

if(!empty($s)){

echo str_replace('SELECT *', 'DELETE', $sql) . ";";

}

}

//echo $sql . "";

}else{

//echo $t . "";

}

}

//print_r($all_tables);

}

search_all_db();

db_sql_query 为查询数据库的方法类,这里不做详细说明。使用时请自行修改代码。

标签:

用手机扫描访问,第一时间获取网站模板更新动态

版权申明:此文如未标注转载均为本站原创,自由转载请表明出处好友资料库。

顶一下 (0)

打赏本站

踩一下 (0)

关闭

感谢您的支持,我会继续努力的!

扫码打赏,你说多少就多少

alipay.jpg

wechat.jpg

下一篇:已经是最后一篇

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP