zoukankan      html  css  js  c++  java
  • mysql循环 insert插入多条数据

     

     
    测试过程中,经常需要造大量的测试数据,手工操作太慢了,所以用mysql的存储过程实现一下:
     
    转载自:https://www.cnblogs.com/fufilforever/p/14362942.html

    开发自测时,数据库需要造大量数据时,要用到Mysql存储过程相关知识,下面分享下,希望对小伙伴们有所帮助:

    CREATE PROCEDURE test() #创建存储函数;
    BEGIN
    DECLARE i INT DEFAULT 1;
    
    WHILE i < 5000 DO
    
    #下面的insert语法要改成自己的表,同时构造value.id,要考虑防重;
    INSERT INTO `wbms_1`.`waybill_weight_volume_2`(`id`, `tenant_id`, `waybill_code`, `operate_code`, `volume`, `weight`, `length`, `width`, `height`, `weight_time`, `volume_time`, `ope_type`, `operator_code`, `operator_name`, `operate_station_code`, `operate_station`, `is_delete`, `create_time`, `update_time`, `create_user`, `update_user`, `ts`) VALUES (1356063857646284800+i, 'test', 'ZY1000502218621', 'ZY1000502218621-1-2-', 55.0000, 55.0000, 5.5000, 55.0000, 55.0000, '2020-09-20 16:39:56', '2020-09-20 16:39:56', 3, '21180252', '陈青山', '308766', '南京江骏营业部', 0, '2021-02-01 10:16:32', '2021-02-01 10:16:32', NULL, NULL, '2021-02-01 10:16:32.000');
    SET i = i+1;
    end WHILE;
    
    END;
    CALL test();#调用存储函数

    下面是我写的存储过程:

    CREATE PROCEDURE wmtest1();  #创建存储过程循环执行,实现插入多条;
    BEGIN
    DECLARE i INT DEFAULT 275;
    WHILE i<276   DO
    INSERT INTO `msg_org_config` VALUES(i,2,'001','工单消息'),
                                       (i,3,'001','一般告警消息'),
                                       (i,4,'001','紧急告警消息'),
                                       (i,5,'001','重要告警消息');
                                       
    SET i=i+1
    END WHILE;
    END;
    CALL wmtest1();#调用存储函数

    注:存储过程一定要写在存储过程窗口里面,不能写在mysql的查询窗口里面,否则会报错的。

    调用可以在查询窗口中。

     

    执行插入语句

    INSERT INTO `org_table` ('org_id','push_way','target_ids','rela_org','push_config') VALUES (246,'02','',246,''),
                                                                                                         (246,'01','',246,'2,3,5,4'),
                                                                                                         (246,'01','124,170,188,227,228,270,271,272,286,287,288',0,'2,3,5,4'),
                                                                                                         (246,'01','129,130,247,261,324,343,350',28,'2,3,5,4');

    一直报错,这里面有个自增的ID,所以我就用了字段,为什么呢?查了半天才 知道,这个字段不能加引号。mysql里加了引号就会报错。

    正确的如下:

     INSERT INTO `org_table` (org_id,push_way,target_ids,rela_org,push_config) VALUES (246,'02','',246,''),
                                                                                                         (246,'01','',246,'2,3,5,4'),
                                                                                                         (246,'01','124,170,188,227,228,270,271,272,286,287,288',0,'2,3,5,4'),
                                                                                                         (246,'01','129,130,247,261,324,343,350',28,'2,3,5,4');

     

  • 相关阅读:
    github release 文件下载贼慢,干脆失败的解决方法
    windows 下sublime text 3 配置python 环境详解
    Ubuntu下安装并使用sublime text 3(建议:先安装Package controls 后在看本教程,否则可能会安装不了)
    将博客搬至CSDN
    signalr core客户端通过ssl连接服务的方式
    解决html导出pdf中文乱码问题的正确姿势
    记一次asp.net core 在iis上运行抛出502.5错误
    Elasticsearch 集群搭建
    bower私服部署
    体验Code::Blocks下的Windows GUI编程(32 bit and 64 bit)
  • 原文地址:https://www.cnblogs.com/yoyoma0355/p/15338568.html
Copyright © 2011-2022 走看看