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

这篇博客介绍了如何在PHP中实现全库搜索关键字,遍历所有表和varchar类型字段,查找并打印含有特定关键字的记录。如果找到含有关键字的记录,还会展示如何构造删除这些记录的SQL语句。
摘要由CSDN通过智能技术生成

场景

刚刚在项目中用到了删除包含某个关键字内容,需要检索整个数据库的所有表、所有字段的值。这里记录一下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 ', $c

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值