mysql批量复制表数据到另外几张表的写法

delimiter //
create procedure oneKey(in newNames varchar(1000),in oldName varchar(250),in id INT,in count INT)
BEGIN
    declare num int; -- 定义变量给循环使用
    set num = 0;
    while num < count
        do
            SET @sqlStmt = CONCAT(‘insert into ‘, -- 要动态修改表名需要concat()方法
                substring_index(substring_index(newNames,‘,‘,(0-count+num)),‘,‘,1), -- 循环截取字符串表名
                ‘ select * from ‘,oldName,‘ where id = ‘,id);  -- 源数据表名
            PREPARE stmt FROM @sqlStmt;
            EXECUTE    stmt;
        set num=num+1;
    end while;
END;
//
delimiter ;

ps : 特别注意concat()方法中拼接的sql语句,逗号拼接处要留有空格!否则会出错!!!

newNames : 要复制数据进去的表名组成的字符串(例:“‘table1‘,‘table2‘,‘table3‘,‘table4‘,……”)

oldName : 源数据表

id : where条件(不需要可以不要)

count : 要复制的新表个数

【重点理解批量的概念 : 程序中循环操作数据库不能算是批量操作!把数据一次性给数据库,数据库自己去循环操作,这种才能算批量操作!!】

原文地址:https://www.cnblogs.com/xuehuashanghe/p/9531160.html

时间: 2024-10-12 07:47:14

mysql批量复制表数据到另外几张表的写法的相关文章

一张表数据分到几张表性能优化

最近在做一个银行项目,从一张表(CCB_CREDIT_TRX)里要往七.八张表写数据, 一开始的做法是把这张表对应的实体select出来,放到一个List集合中,再对这个LIST List<CcbCreditTrx> list = new ArrayList<CcbCreditTrx>;//对这个List遍历for(CcbCreditTrx ccbCreditTrx:list) { //这里处理对其他表的操作 //表A .... //表B .... //表C .... } 建议做法

sql 表数据转移另一张表

if not exists(select * from syscolumns where id=object_id('REMOTEDETECTION_2018')) begin SELECT * INTO  REMOTEDETECTION_2018  FROM REMOTEDETECTION  where 1=0  end; insert into RemoteDetections(DETECTIONSTATE,PASSDATETIME,VLPN,VLPNCOLOR,FUELTYPE,BZTYP

MySQL批量导入Excel数据

MySQL批量导入Excel数据 1.确定需要导入数据的表名称以及字段,然后在新建的Excel表中,按照表字段正确排序:(注:(Excel文件的名称最好和数据库的名称一致,sheet表的名字最好和表名称一致,方便需要导入多张表数据时一一对应)) 2.在Excel表中,正确填写需要导入的数据,一行数据对应着数据库表中的一行记录:(注:各个字段的格式要求需要和数据库中的限制一样,避免出现差错) 3.收集好需要导入的数据后,点击保存.(注:导入的时候,Excel文件处于打开状态) 4.选中需要导入数据

mysql进阶 十五 mysql批量删除大量数据

mysql批量删除大量数据 假设有一个表(syslogs)有1000万条记录,需要在业务不停止的情况下删除其中statusid=1的所有记录,差不多有600万条, 直接执行 DELETE FROM syslogs WHERE statusid=1 会发现删除失败,因为lock wait timeout exceed的错误. 因为这条语句所涉及的记录数太多,因此我们通过LIMIT参数分批删除,比如每10000条进行一次删除,那么我们可以利用 MySQL这样的语句来完成: DELETE FROM s

复制一张表的数据到另一张表,jq.grid里面有时间类型数据时展示不了数据

1.复制一张表的数据到另一张表 insert into jct_sys_lock_tbl_new  (BGN_DT, END_DT, TYPE, DESCR, flag, format, range, count)  select BGN_DT, END_DT, TYPE, DESCR, flag, format, range, count    from jct_sys_lock_tbl 也可以: insert into jct_sys_lock_tbl_new  select *    fr

13 | 为什么表数据删掉一半,表文件大小不变?

经常会有同学来问我,我的数据库占用空间太大,我把一个最大的表删掉了一半的数据,怎么表文件的大小还是没变? 那么今天,我就和你聊聊数据库表的空间回收,看看如何解决这个问题. 这里,我们还是针对MySQL中应用最广泛的InnoDB引擎展开讨论.一个InnoDB表包含两部分,即:表结构定义和数据.在MySQL 8.0版本以前,表结构是存在以.frm为后缀的文件里.而MySQL 8.0版本,则已经允许把表结构定义放在系统数据表中了.因为表结构定义占用的空间很小,所以我们今天主要讨论的是表数据. 接下来,

Sql从一张表中更改另一张表数据

语法: update table1 set table1.列=table2.列 from table2 where table2.列=table1.列update NFYSP.dbo.PATIENT     setPATIENT_ADDUSERID=OLD.PATIENT_ADDUSERID,PATIENT_UPDATEUSERID=OLD.PATIENT_UPDATEUSERID,PATIENT_UPDATEUSERNAME=OLD.PATIENT_UPDATEUSERNAME,PATIENT

SQLserver将一张表a的数据插入另一张表b

一.将一张表a的数据插入另一张表b(b为新建表) select * into 表b  from 表a 二.将一张表a的数据插入另一张表b(b为已有表) insert into 表b select * from 表a

mysql 从相同类型的多张表中提取到一张表中

蜗牛背着沉重的壳,贴着地面一步步艰难地向前爬行,不回头,也不左顾右盼,只是朝着自己想到达的地方行进. 有时候需要从多张相同类型的表中提取数据,这些表有一些相同的列或者表结构完全相同,同时表名存在一定的规律,如果表数量少还好,如果表数量多的话则会比较繁琐.可以通过存储过程将多张表的数据提取到一张表的方法来降低工作量. 先创建测试表并生成测试数据.以下存储过程创建10张测试表,每张表生成10条测试数据.drop PROCEDURE if EXISTS create10tables;create PR