网站推荐、资源下载等 | 个人网站

【mysql】存储过程,查询/替换指定数据库、具体编码类型含有某字符串的所有表名和列名

1、需求:就是想在一个数据库中查找存在某字符串的表和列;

2、例子,我这里my_test数据库有3张表,test_replace的name、password列有张三字符串,t1表的name、city列也有张三字符串,t_user表就没有张三字符串。

 

 

 

 

 

 

 

 运行结果

 

 t1,name;t1,city;test_replace,name;test_replace,password

符合要求

3、代码

-- 1.将mysql分隔符从;设置为&
DELIMITER &
-- 2.如果存在存储过程getCount则删除
DROP PROCEDURE IF EXISTS `getCount` &
-- 3.定义存储过程,获取特定表列关键词的数量
-- (传入参数table_name字符串类型,为表名;传入参数column_name字符串类型,为列名;传入参数key_name字符串类型,为关键字;传出参数count_date整数类型,为数量)
CREATE DEFINER=`root`@`localhost` PROCEDURE getCount(IN table_name CHAR(200), IN column_name CHAR(200), IN key_name CHAR(20), OUT count_date INT) 
    BEGIN
    -- 4.声明变量
    DECLARE $sqltext VARCHAR(1000);
    -- 5.动态sql,把sql返回值放到@count_date中
    SET $sqltext = CONCAT('SELECT COUNT(*) into @count_date FROM ', table_name, ' where ', table_name, '.', column_name, ' LIKE \'%', key_name, '%\';');
    SET @sqlcounts := $sqltext;
    -- 6.预编释,stmt预编释变量的名称
    PREPARE stmt FROM @sqlcounts;
    -- 7.执行SQL语句
    EXECUTE stmt; 
    -- 8.释放资源
    DEALLOCATE PREPARE stmt;
    -- 9.获取动态SQL语句返回值
    SET count_date = @count_date;
    END
-- 10.定义存储过程结束
&

-- 11.如果存在存储过程getTableColumnNames则删除
DROP PROCEDURE IF EXISTS `getTableColumnNames` &
-- 12.定义存储过程,获取指定数据库关键词的表列名
-- (传入参数database_n字符串类型,数据库名;传入参数collation_n字符串类型,具体编码类型;传入参数key_name字符串类型,为关键字;传出参数tableColumnNames字符串类型,表列名)
CREATE DEFINER=`root`@`localhost` PROCEDURE getTableColumnNames(IN database_n CHAR(20), IN collation_n CHAR(32), IN key_name CHAR(20), OUT tableColumnNames TEXT) 
    BEGIN
    -- 13.声明变量。database_name查询出来的数据库,table_name查询出来的表名,column_name查询出来的列名,collation_name查询出来的具体编码类型
    DECLARE database_name, table_name, column_name, collation_name CHAR(200);
    DECLARE tableColumnStr TEXT DEFAULT '';
    DECLARE resoult_count INT DEFAULT 0;
    -- 14.定义游标结束标识,默认为0
    DECLARE stopflag INT DEFAULT 0;
    -- 15.定义游标,其实就是临时存储sql返回的集合
    DECLARE sql_resoult CURSOR FOR SELECT t.TABLE_SCHEMA, t.TABLE_NAME, t.COLUMN_NAME, t.COLLATION_NAME FROM information_schema.COLUMNS t;
    -- 16.游标结束就设置为1
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET stopflag=1;
    -- 17.打开游标
    OPEN sql_resoult;
        -- 18.读取游标中数据,存储到指定变量
        FETCH sql_resoult INTO database_name, table_name, column_name, collation_name;
        -- 19.没有结束继续往下走
        WHILE (stopflag=0) DO
            BEGIN
            -- 20.判断数据库是否为输入的数据库名称,和,指定具体编码类型,和,不含.
            IF (database_name=database_n AND collation_name=collation_n AND LOCATE('.', column_name)=0) THEN
                -- 21.调用存储过程,获取特定表列关键词的数量
                CALL getCount(table_name, column_name, key_name, resoult_count);
                -- 22.如果数量不等于0,那么记录表列名
                IF (resoult_count <> 0) THEN
                    -- 23.拼接字符串,不可直接用传出变量设值
            IF (tableColumnStr IS NULL OR tableColumnStr='') THEN
                SET tableColumnStr=CONCAT(table_name, ',', column_name);
            ELSE
                SET tableColumnStr=CONCAT(tableColumnStr, ';', table_name, ',', column_name);
            END IF;
                END IF;
            END IF;
            -- 24.读取游标中数据,存储到指定变量。(和18一样)
            FETCH sql_resoult INTO database_name, table_name, column_name, collation_name;
            END;
        END WHILE;
    -- 25.关闭游标
    CLOSE sql_resoult;
    -- 26.把数据放到传出参数
    SET tableColumnNames=tableColumnStr;
    END
-- 27.定义存储过程结束
&

-- 28.将mysql分隔符从&设置为;
DELIMITER ;
-- 29.设置变量
SET @tableColumnNames='';
SET @database='my_test';
SET @collation_name='utf8_general_ci';
SET @key='张三';
-- 30.调用存储过程
CALL getTableColumnNames(@database, @collation_name, @key, @tableColumnNames);
-- 31.打印
SELECT @tableColumnNames;
-- 32.如果存在存储过程则删除
DROP PROCEDURE IF EXISTS `getCount`;
DROP PROCEDURE IF EXISTS `getTableColumnNames`;

 

注:如果数据库很多,建议在存储过程中指定数据库,这样减少查询的数据量。下面的代码,记得把my_test换成自己要查询的数据库名称。

 

-- 1.将mysql分隔符从;设置为&
DELIMITER &
-- 2.如果存在存储过程getCount则删除
DROP PROCEDURE IF EXISTS `getCount` &
-- 3.定义存储过程,获取特定表列关键词的数量
-- (传入参数table_name字符串类型,为表名;传入参数column_name字符串类型,为列名;传入参数key_name字符串类型,为关键字;传出参数count_date整数类型,为数量)
CREATE DEFINER=`root`@`localhost` PROCEDURE getCount(IN table_name CHAR(200), IN column_name CHAR(200), IN key_name CHAR(20), OUT count_date INT) 
    BEGIN
    -- 4.声明变量
    DECLARE $sqltext VARCHAR(1000);
    -- 5.动态sql,把sql返回值放到@count_date中
    SET $sqltext = CONCAT('SELECT COUNT(*) into @count_date FROM ', table_name, ' where ', table_name, '.', column_name, ' LIKE \'%', key_name, '%\';');
    SET @sqlcounts := $sqltext;
    -- 6.预编释,stmt预编释变量的名称
    PREPARE stmt FROM @sqlcounts;
    -- 7.执行SQL语句
    EXECUTE stmt; 
    -- 8.释放资源
    DEALLOCATE PREPARE stmt;
    -- 9.获取动态SQL语句返回值
    SET count_date = @count_date;
    END
-- 10.定义存储过程结束
&

-- 11.如果存在存储过程getTableColumnNames则删除
DROP PROCEDURE IF EXISTS `getTableColumnNames` &
-- 12.定义存储过程,获取指定数据库关键词的表列名
-- (传入参数collation_n字符串类型,具体编码类型;传入参数key_name字符串类型,为关键字;传出参数tableColumnNames字符串类型,表列名)
CREATE DEFINER=`root`@`localhost` PROCEDURE getTableColumnNames(IN collation_n CHAR(32), IN key_name CHAR(20), OUT tableColumnNames TEXT) 
    BEGIN
    -- 13.声明变量。table_name查询出来的表名,column_name查询出来的列名,collation_name查询出来的具体编码类型
    DECLARE table_name, column_name, collation_name CHAR(200);
    DECLARE tableColumnStr TEXT DEFAULT '';
    DECLARE resoult_count INT DEFAULT 0;
    -- 14.定义游标结束标识,默认为0
    DECLARE stopflag INT DEFAULT 0;
    -- 15.定义游标,其实就是临时存储sql返回的集合
    DECLARE sql_resoult CURSOR FOR SELECT t.TABLE_NAME, t.COLUMN_NAME, t.COLLATION_NAME FROM information_schema.COLUMNS t WHERE t.TABLE_SCHEMA='my_test';
    -- 16.游标结束就设置为1
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET stopflag=1;
    -- 17.打开游标
    OPEN sql_resoult;
        -- 18.读取游标中数据,存储到指定变量
        FETCH sql_resoult INTO table_name, column_name, collation_name;
        -- 19.没有结束继续往下走
        WHILE (stopflag=0) DO
            BEGIN
            -- 20.指定具体编码类型,和,不含.
            IF (collation_name=collation_n AND LOCATE('.', column_name)=0) THEN
                -- 21.调用存储过程,获取特定表列关键词的数量
                CALL getCount(table_name, column_name, key_name, resoult_count);
                -- 22.如果数量不等于0,那么记录表列名
                IF (resoult_count <> 0) THEN
                    -- 23.拼接字符串,不可直接用传出变量设值
                    IF (tableColumnStr IS NULL OR tableColumnStr='') THEN
                        SET tableColumnStr=CONCAT(table_name, ',', column_name);
                    ELSE
                        SET tableColumnStr=CONCAT(tableColumnStr, ';', table_name, ',', column_name);
                    END IF;
                END IF;
            END IF;
            -- 24.读取游标中数据,存储到指定变量。(和18一样)
            FETCH sql_resoult INTO table_name, column_name, collation_name;
            END;
        END WHILE;
    -- 25.关闭游标
    CLOSE sql_resoult;
    -- 26.把数据放到传出参数
    SET tableColumnNames=tableColumnStr;
    END
-- 27.定义存储过程结束
&

-- 28.将mysql分隔符从&设置为;
DELIMITER ;
-- 29.设置变量
SET @tableColumnNames='';
SET @collation_name='utf8_general_ci';
SET @key='张三';
-- 30.调用存储过程
CALL getTableColumnNames(@collation_name, @key, @tableColumnNames);
-- 31.打印
SELECT @tableColumnNames;
-- 32.如果存在存储过程则删除
DROP PROCEDURE IF EXISTS `getCount`;
DROP PROCEDURE IF EXISTS `getTableColumnNames`;
View Code

 

无注释版

DELIMITER &
DROP PROCEDURE IF EXISTS `getCount` &
CREATE DEFINER=`root`@`localhost` PROCEDURE getCount(IN table_name CHAR(200), IN column_name CHAR(200), IN key_name CHAR(40), OUT count_date INT) 
    BEGIN
    DECLARE $sqltext VARCHAR(1000);
    SET $sqltext = CONCAT('SELECT COUNT(*) into @count_date FROM ', table_name, ' where ', table_name, '.', column_name, ' LIKE \'%', key_name, '%\';');
    SET @sqlcounts := $sqltext;
    PREPARE stmt FROM @sqlcounts;
    EXECUTE stmt; 
    DEALLOCATE PREPARE stmt;
    SET count_date = @count_date;
    END
&

DROP PROCEDURE IF EXISTS `getTableColumnNames` &
CREATE DEFINER=`root`@`localhost` PROCEDURE getTableColumnNames(IN collation_n CHAR(32), IN key_name CHAR(40), OUT tableColumnNames TEXT) 
    BEGIN
    DECLARE table_name, column_name, collation_name CHAR(200);
    DECLARE tableColumnStr TEXT DEFAULT '';
    DECLARE resoult_count INT DEFAULT 0;
    DECLARE stopflag INT DEFAULT 0;
    DECLARE sql_resoult CURSOR FOR SELECT t.TABLE_NAME, t.COLUMN_NAME, t.COLLATION_NAME FROM information_schema.COLUMNS t WHERE t.TABLE_SCHEMA='my_test';
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET stopflag=1;
    OPEN sql_resoult;
        FETCH sql_resoult INTO table_name, column_name, collation_name;
        WHILE (stopflag=0) DO
            BEGIN
            IF (collation_name=collation_n AND LOCATE('.', column_name)=0) THEN
                CALL getCount(table_name, column_name, key_name, resoult_count);
                IF (resoult_count <> 0) THEN
                    IF (tableColumnStr IS NULL OR tableColumnStr='') THEN
                        SET tableColumnStr=CONCAT(table_name, ',', column_name);
                    ELSE
                        SET tableColumnStr=CONCAT(tableColumnStr, ';\n', table_name, ',', column_name);
                    END IF;
                END IF;
            END IF;
            FETCH sql_resoult INTO table_name, column_name, collation_name;
            END;
        END WHILE;
    CLOSE sql_resoult;
    SET tableColumnNames=tableColumnStr;
    END
&

DELIMITER ;
SET @tableColumnNames='';
SET @collation_name='utf8_general_ci';
SET @key='张三';
CALL getTableColumnNames(@collation_name, @key, @tableColumnNames);
SELECT @tableColumnNames;
DROP PROCEDURE IF EXISTS `getCount`;
DROP PROCEDURE IF EXISTS `getTableColumnNames`;

 

4、替换字符串,把test_database换成自己数据库,把张三换成李四。

 1 DELIMITER &
 2 DROP PROCEDURE IF EXISTS `updateKey` &
 3 CREATE DEFINER=`root`@`localhost` PROCEDURE updateKey(IN table_name CHAR(200), IN column_name CHAR(200), IN key_name CHAR(40), IN replace_key_name CHAR(40), OUT count_date INT) 
 4     BEGIN
 5     DECLARE $sqltext VARCHAR(1000);
 6     SET $sqltext = CONCAT('SELECT COUNT(*) into @count_date FROM ', table_name, ' where ', table_name, '.', column_name, ' LIKE \'%', key_name, '%\';');
 7     SET @sqlcounts := $sqltext;
 8     PREPARE stmt FROM @sqlcounts;
 9     EXECUTE stmt; 
10     DEALLOCATE PREPARE stmt;
11 
12     IF (@count_date <> 0) THEN
13         SET $sqltext = CONCAT('UPDATE ', table_name, ' SET ', column_name, ' = REPLACE(', column_name, ', \'', key_name, '\', \'', replace_key_name, '\') WHERE ', column_name, ' LIKE \'%', key_name, '%\';');
14         SET @sqlcounts := $sqltext;
15         PREPARE stmt FROM @sqlcounts;
16         EXECUTE stmt; 
17         DEALLOCATE PREPARE stmt;
18     END IF;
19 
20     SET count_date = @count_date;
21     END
22 &
23 
24 DROP PROCEDURE IF EXISTS `getTableColumnNames` &
25 CREATE DEFINER=`root`@`localhost` PROCEDURE getTableColumnNames(IN collation_n CHAR(64), IN key_name CHAR(40), IN replace_key_name CHAR(40), OUT tableColumnNames TEXT) 
26     BEGIN
27     DECLARE table_name, column_name, collation_name CHAR(200);
28     DECLARE tableColumnStr TEXT DEFAULT '';
29     DECLARE resoult_count INT DEFAULT 0;
30     DECLARE stopflag INT DEFAULT 0;
31     DECLARE sql_resoult CURSOR FOR SELECT t.TABLE_NAME, t.COLUMN_NAME, t.COLLATION_NAME FROM information_schema.COLUMNS t WHERE t.TABLE_SCHEMA='test_database';
32     DECLARE CONTINUE HANDLER FOR NOT FOUND SET stopflag=1;
33     OPEN sql_resoult;
34         FETCH sql_resoult INTO table_name, column_name, collation_name;
35         WHILE (stopflag=0) DO
36             BEGIN
37             IF (FIND_IN_SET(collation_name, collation_n)>0 AND LOCATE('.', column_name)=0) THEN
38                 CALL updateKey(table_name, column_name, key_name, replace_key_name, resoult_count);
39                 IF (resoult_count <> 0) THEN
40                     IF (tableColumnStr IS NULL OR tableColumnStr='') THEN
41                         SET tableColumnStr=CONCAT(table_name, ',', column_name);
42                     ELSE
43                         SET tableColumnStr=CONCAT(tableColumnStr, ';\n', table_name, ',', column_name);
44                     END IF;
45                 END IF;
46             END IF;
47             FETCH sql_resoult INTO table_name, column_name, collation_name;
48             END;
49         END WHILE;
50     CLOSE sql_resoult;
51     SET tableColumnNames=tableColumnStr;
52     END
53 &
54 
55 DELIMITER ;
56 SET @tableColumnNames='';
57 SET @collation_name='utf8_general_ci,utf8mb4_general_ci';
58 SET @key='张三';
59 SET @replace_key='李四';
60 CALL getTableColumnNames(@collation_name, @key, @replace_key, @tableColumnNames);
61 SELECT @tableColumnNames;
62 DROP PROCEDURE IF EXISTS `updateKey`;
63 DROP PROCEDURE IF EXISTS `getTableColumnNames`;

 

posted @ 2020-02-19 12:06  xiaostudy  阅读(973)  评论(0)    收藏  举报
网站推荐
[理工最爱]小时百科 |  GitHub |  Gitee |  开源中国社区 |  牛客网 |  不学网论坛 |  r2coding |  冷熊简历 |  爱盘 |  零散坑 |  bootstrap中文网 |  vue.js官网教程 |  源码分享站 |  maven仓库 |  楼教主网站 |  廖雪峰网站 |  w3cschool |  在线API |  代码在线运行 |  [不学网]代码在线运行 |  JS在线运行 |  PHP中文网 |  深度开源eclipse插件 |  文字在线加密解密 |  菜鸟教程 |  慕课网 |  千图网 |  手册网 |  素材兔 |  盘多多 |  悦书PDF |  sumatra PDF |  calibre PDF |  Snipaste截图 |  shareX截图 |  vlc-media-player播放器 |  MCMusic player |  IDM下载器 |  格式工厂 |  插件网 |  谷歌浏览器插件 |  Crx搜搜 |  懒人在线计算器 |  leetcode算法题库 |  layer官网 |  layui官网 |  formSelects官网 |  Fly社区 |  程序员客栈 |  融云 |  华为云 |  阿里云 |  ztree官网API |  teamviewer官网 |  sonarlint官网 |  editormd |  pcmark10官网 |  crx4chrome官网 |  apipost官网 |  花生壳官网 |  serv-u官网 |  杀毒eset官网 |  分流抢票bypass官网 |  懒猴子CG代码生成器官网 |  IT猿网 |  natapp[内网穿透] |  ngrok[内网穿透] |  深蓝穿透[内网穿透] |  WakeMeOnLan[查看ip] |  iis7 |  [漏洞扫描]Dependency_Check官网 |  [图标UI]fontawesome官网 |  idea插件官网 |  路过图床官网 |  sha256在线解密 |  在线正则表达式测试 |  在线文件扫毒 |  KuangStudy | 
资源下载
电脑相关: Windows原装下载msdn我告诉你 |  U盘制作微PE工具官网下载 |  Linux_CentOS官网下载 |  Linux_Ubuntu官网下载 |  Linux_OpenSUSE官网下载 |  IE浏览器官网下载 |  firefox浏览器官网下载 |  百分浏览器官网下载 |  谷歌google浏览器历史版本下载 |  深度deepin系统官网下载 |  中兴新支点操作系统官网下载 |  文件对比工具Beyond Compare官网下载 |  开机启动程序startup-delayer官网下载 |  openoffice官网下载 |  utorrent官网下载 |  qbittorrent官网下载 |  cpu-z官网下载 |  蜘蛛校色仪displaycal官网下载 |  单文件制作greenone下载 |  win清理工具Advanced SystemCare官网下载 |  解压bandizip官网下载 |  内存检测工具memtest官网下载 |  磁盘坏道检测与修复DiskGenius官网下载 |  磁盘占用可视化SpaceSniffer官网下载 |  [磁盘可视化]WizTree官网下载 |  win快速定位文件Everything官网下载 |  文件定位listary官网下载 |  动图gifcam官网下载 |  7-Zip官网下载 |  磁盘分区工具diskgenius官网下载 |  CEB文件查看工具Apabi Reader官网下载 |  罗技鼠标options官网下载 |  [去除重复文件]doublekiller官网下载 | 
编程相关: ApacheServer官网下载 |  Apache官网下载 |  Git官网下载 |  Git高速下载 |  Jboss官网下载 |  Mysql官网下载 |  Mysql官网历史版本下载 |  NetBeans IDE官网下载 |  Spring官网下载 |  Nginx官网下载 |  Resin官网下载 |  Tomcat官网下载 |  jQuery历史版本下载 |  nosql官网下载 |  mongodb官网下载 |  mongodb_linux历史版本下载 |  mongodb客户端下载 |  VScode官网下载 |  cxf官网下载 |  maven官网下载 |  QT官网下载 |  SVN官网下载 |  SVN历史版本下载 |  nodeJS官网下载 |  oracle官网下载 |  jdk官网下载 |  STS官网下载 |  STS历史版本官网下载 |  vue官网下载 |  virtualbox官网下载 |  docker desktop官网下载 |  github desktop官网下载 |  EditPlus官网下载 |  zTree下载 |  layui官网下载 |  jqgrid官网下载 |  jqueryui官网下载 |  solr历史版本下载 |  solr分词器ik-analyzer-solr历史版本下载 |  zookeeper历史版本官网下载 |  nssm官网下载 |  elasticsearch官网下载 |  elasticsearch历史版本官网下载 |  redis官网下载 |  redis历史版本官网下载 |  redis的win版本下载 |  putty官网下载 |  查看svn密码TSvnPD官网下载 |  MongoDB连接工具Robo官网下载 |  dll查看exescope官网下载 |  dll2c官网下载 |  接口测试apipost官网下载 |  接口测试postman官网下载 |  原型设计工具AxureRP官网下载 |  canal官网下载 |  idea主题样式下载 |  vue的GitHub下载 |  finalShell官网下载 |  ETL工具kafka官网下载 |  cavaj[java反编译]官网下载 |  jd-gui[java反编译]官网下载 |  radmin[远程连接]官网下载 |  tcping[win ping端口]下载 |  jQueryUploadFile官网下载 |  RedisPlus下载 |  aiXcoder智能编程助手官网下载 |  [表单效验]validform官网下载 |  idea官网下载 |  RedisStudio下载 |  MD转word含公式pandoc官网下载 |  logviewer官网下载 |  Kafka官网下载 |  hbase高速下载 |  hadoop官网下载 |  hadooponwindows的GitHub下载 |  hive官网下载 |  soapui官网下载 |  flink官网下载 |  kafkatool官网下载 |  MinIO官网下载 |  MinIO中国镜像下载 | 
办公相关工具
免费在线拆分PDF【不超过30M】 |  免费在线PDF转Word【不超过10M】 |  在线文字识别转换【不超过1M】 |  PDF转换成Word【不超过50M】 |  在线OCR识别 |  Smallpdf |  文件转换器Convertio |  迅捷PDF转换器 |  字母大小写转换工具 |  档铺 |  快传airportal[可文字] |  快传-文叔叔 |  P2P-小鹿快传 |  [图床]ImgURL | 
网站入口
腾讯文档 |  有道云笔记网页版 |  为知笔记网页版 |  印象笔记网页版 |  蓝奏云 |  QQ邮箱 |  MindMaster在线思维导图 |  bilibili |  PDM文件在线打开 |  MPP文件在线打开 |  在线PS软件 |  在线WPS |  阿里云企业邮箱登陆入口 | 
其他
PDF转换 |  悦书PDF转换 |  手机号注册查询 |  Reg007 |  akmsg |  ip8_ip查询 |  ipip_ip查询 |  天体运行testtubegames |  测试帧率 |  在线网速测试 |