• MySQL根据表前缀批量修改、删除表


    注意:请先调试好,以及做好备份,再执行操作。

    批量修改表

    批量给前缀为 xushanxiang_content_ 的表增加一个 username 的字段:

    SELECT CONCAT('ALTER TABLE ',table_name,' ADD username varchar(40) NULL COMMENT "用户名";') FROM information_schema.TABLES WHERE table_name LIKE 'xushanxiang\_content\_%';

    可以得到下面一些 SQL 语句列表,也就是生成了批量修改表的语句:

    之后,我们再批量执行这些 SQL 语句即可。

    批量执行语句

    方式一、存储过程 while 循环

    # 参考代码:
    DROP PROCEDURE IF EXISTS canal_test; # 删除存储过程
    
    DELIMITER // # 设置分割符1
    CREATE PROCEDURE canal_test()
    BEGIN
    DECLARE i INT DEFAULT 0;
    WHILE i<=10 DO
       update users set mileage=i;
    SET i = i+1;
    END WHILE;
    END
    //
    DELIMITER; # 设置分割符2
    
    CALL canal_test(); # 调用存储过程
     

    方式二、source 命令

    待执行的 sql 文件为1.sql、2.sql、3.sql、4.sql等, 写一个batch.sql文件:

    source 1.sql;
    source 2.sql;
    source 3.sql;

    在 mysql 下执行 source batch.sql; (注意路径)

    如果只有一个 SQL 文件,例如 mysqltest.sql 脚本在 D 盘根目录, 进入 MySQL 的命令行窗口,直接输入如下命令即可批量执行脚本中的 sql 语句【 注:结尾不带分号执行 】

    source D:\mysqltest.sql

    方式三、在网站程序里动态执行

    // 参考用例,可能和您的实际情况不一样
    $sqlArr = $this->model->all("SELECT CONCAT('ALTER TABLE ',table_name,' ADD username varchar(40) NULL COMMENT \'用户名\';') FROM information_schema.TABLES WHERE table_name LIKE 'xushanxiang\_content\_%';");
    // 得到一个SQL语句的数组;
    foreach ($sqlArr as $key => $value) {
        foreach ($value as $k => $v) {
            $this->model->amd($v); // 依次执行sql
        }
    }
     

    批量删除

    参考 sql 如下:

    SELECT CONCAT('drop table ',table_name,';') FROM information_schema.TABLES WHERE table_name LIKE 'xushanxiang\_content\_%';

    接着,参考上面的进行批量执行即可。

    题外话,既然说到对数据表进行批量操作,那可能少不了数据表的复制。

    数据表的复制

    只复制表结构到新表

    create table 新表 like 旧表

    复制表结构及数据到新表

    create table 新表 select * from 旧表

    复制一条数据到结构相同的表

    INSERT INTO content_1 SELECT * FROM content_0 WHERE id=1

    复制部分字段到另一个表

    INSERT INTO table2 ( name , price ) SELECT name , price  FROM table1  WHERE id=5
    

    出处:MySQL根据表前缀批量修改、删除表 (xushanxiang.com)

  • 相关阅读:
    python __init__(构造函数)方法的使用
    【视觉SLAM入门】9.1 建图1---SLAM任务,稠密地图构建,立体视觉,RGBD,八叉树,点云地图等各种不同地图
    按位异或的应用
    一顶帐篷创收六亿,骆驼有何秘籍?
    React项目引入Antd后经过Webpack打包,没有任何报错,但是组件样式不生效。
    常用激活函数的选取
    CSCMS代码审计
    flutter系列之:flutter中的变形金刚Transform
    小程序基础
    【软件开发面经】大厂面试经验
  • 原文地址:https://www.cnblogs.com/xusx2014/p/16410553.html