mysql表字段反查表名脚本-筛选法-查表技巧

思路:

先筛表缩小范围,再找就好了 ;;

bash 复制代码
高级模糊搜字段:
SELECT
    table_name,
    column_name
FROM
    information_schema.columns
WHERE
    table_schema = DATABASE()
    -- 核心处理逻辑:
    -- 1. 将 column_name 中的所有下划线移除(REPLACE(column_name, '_', ''))
    -- 2. 将结果转换为小写(LOWER(...))
    -- 3. 与搜索词(同样经过处理)进行 LIKE 匹配
    AND LOWER(REPLACE(column_name, '_', '')) LIKE CONCAT('%', LOWER(REPLACE('testfiled', '_', '')), '%');
    

存储过程脚本 ,查询非空表;

bash 复制代码
DELIMITER $$

-- 如果已存在同名存储过程,先删除
DROP PROCEDURE IF EXISTS SearchColumnWithData$$

-- 定义带参数的存储过程
CREATE PROCEDURE SearchColumnWithData(IN searchKeyword VARCHAR(100))
BEGIN
    -- 定义变量
    DECLARE done INT DEFAULT FALSE;
    DECLARE target_table VARCHAR(255);
    DECLARE target_col VARCHAR(255);
    -- 游标
    DECLARE cur CURSOR FOR 
        SELECT table_name, column_name
        FROM information_schema.columns 
        WHERE table_schema = DATABASE()
        -- 这里使用传入的 searchKeyword 参数,替换原来的固定字符串
        AND LOWER(REPLACE(column_name, '_', '')) LIKE CONCAT('%', LOWER(REPLACE(searchKeyword, '_', '')), '%');
        
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
    
    -- 创建临时表存结果
    DROP TEMPORARY TABLE IF EXISTS temp_search_result;
    CREATE TEMPORARY TABLE temp_search_result (
        tbl_name VARCHAR(255),
        col_name VARCHAR(255),
        row_count INT
    );

    OPEN cur;
    
    read_loop: LOOP
        FETCH cur INTO target_table, target_col;
        IF done THEN
            LEAVE read_loop;
        END IF;
        
        -- 动态构建 SQL:查询该表的总行数
        SET @s = CONCAT('INSERT INTO temp_search_result SELECT ''', target_table, ''', ''', target_col, ''', COUNT(*) FROM ', target_table);
        
        -- 执行动态 SQL
        PREPARE stmt FROM @s;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;
        
    END LOOP;

    CLOSE cur;

    -- 输出结果:只显示有数据的表
    SELECT * FROM temp_search_result WHERE row_count > 0 ORDER BY row_count DESC;
    
    -- 清理
    DROP TEMPORARY TABLE IF EXISTS temp_search_result;
END$$

DELIMITER ;

使用方法:

bash 复制代码
CALL SearchColumnWithData('fdUnionId');

方法三:

相关推荐
倔强的石头_10 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端