首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在MySQL数据库的每个表的字段中搜索文本

在MySQL数据库的每个表的字段中搜索文本
EN

Stack Overflow用户
提问于 2009-03-12 16:57:13
回答 19查看 512.7K关注 0票数 336

我希望在MySQL数据库的所有表的所有字段中搜索给定的字符串,可能使用如下语法:

代码语言:javascript
复制
SELECT * FROM * WHERE * LIKE '%stuff%'

有可能做这样的事情吗?

EN

回答 19

Stack Overflow用户

回答已采纳

发布于 2009-03-12 17:00:20

您可以查看information_schema模式。它有一个包含所有表和表中所有字段的列表。然后,您可以使用从该表中获得的信息来运行查询。

涉及到的表有模式、表和列。有一些外键,这样您就可以准确地构建在模式中创建表的方式。

票数 85
EN

Stack Overflow用户

发布于 2011-01-27 21:51:17

您可以对数据库(及其数据)执行SQLDump,然后搜索该文件。

票数 468
EN

Stack Overflow用户

发布于 2011-03-08 23:58:44

PHP函数:

代码语言:javascript
复制
function searchAllDB($search){
    global $mysqli;
    
    $out = Array();
    
    $sql = "show tables";
    $rs = $mysqli->query($sql);
    if($rs->num_rows > 0){
        while($r = $rs->fetch_array()){
            $table = $r[0];
            $sql_search = "select * from `".$table."` where ";
            $sql_search_fields = Array();
            $sql2 = "SHOW COLUMNS FROM `".$table."`";
            $rs2 = $mysqli->query($sql2);
            if($rs2->num_rows > 0){
                while($r2 = $rs2->fetch_array()){
                    $column = $r2[0];
                    $sql_search_fields[] = "`".$column."` like('%".$mysqli->real_escape_string($search)."%')";
                }
                $rs2->close();
            }
            $sql_search .= implode(" OR ", $sql_search_fields);
            $rs3 = $mysqli->query($sql_search);
            $out[$table] = $rs3->num_rows."\n";
            if($rs3->num_rows > 0){
                $rs3->close();
            }
        }
        $rs->close();
    }
    
    return $out;
}

print_r(searchAllDB("search string"));
票数 48
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/639531

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档