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');

方法三:

相关推荐
2301_793804692 小时前
深入理解Python的if __name__ == ‘__main__‘
jvm·数据库·python
勇者无畏4042 小时前
基于 Spring AI Alibaba 搭建 Text-To-SQL 智能系统(简单实现)
数据库·sql
2401_833197732 小时前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
暮冬-  Gentle°2 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python
2401_891655812 小时前
MySQL安全加固十大硬核操作技术大纲
数据库·mysql·安全
hongtianzai2 小时前
Laravel9.X核心特性全解析
android·java·数据库
dovens2 小时前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
电商API_180079052472 小时前
电商平台公开数据采集实践:基于合规接口的数据分析方案
开发语言·数据库·人工智能·数据挖掘·数据分析·网络爬虫
小陈工2 小时前
2026年3月22日技术资讯洞察:数据库优化进入预测时代,网络安全威胁全面升级
java·开发语言·数据库·python·安全·web安全·django
l1t2 小时前
DeepSeek总结的PostgreSQL 无需生产数据,即可获取生产查询计划
数据库·postgresql