mysql函数大批量插入数据+java多线程并发案例

为了进行性能测试,创建了一个MySQL函数来批量插入5000万条数据。函数采用循环和事务处理,防止大量插入导致失败。为提升效率,通过Java多线程并发执行任务,实现数据的快速生成。这种方案适用于大批量数据处理,能有效缩短执行时间并提高效率。
摘要由CSDN通过智能技术生成

当前需要做个测试,mysql数据库需要5000万数据来完成性能测试,于是我们写了个函数来完成这个功能。

函数定义如下:

#批量插入数据库的函数
BEGIN
    #定义需要插入数据库表中的字段;
 
    DECLARE id BIGINT(20);
    DECLARE phone_number varchar(11);
 
    #定义变量控制插入数据库表的行数
    DECLARE sid bigint(20) DEFAULT 1;
    DECLARE count bigint(20);
    declare total bigint(20) DEFAULT 50000000;

    #开启循环判断
    while sid < total do
        SET count = sid + 100000; //每次插入数据库条数,防止条数太多提交失败;

    #开始事务
    start transaction;
    WHILE (sid < count) DO //循环插入数据库数据
    SET id = sid;
    SET phone_number = CONCAT(1, ROUND(ROUND(RAND(),10)*10000000000));
    INSERT INTO t_contact_phone(sid,phone_number)
    VALUES(id,phone_number);
    #累计行数
    SET sid = sid+1;
    END WHILE;
    commit;  //提交事务
  end while; //结束循环
END


执行上述函数即可创建5000万条数据在测试库用于测试。

当我们需要同时执行大批量操作,那如果依然顺序单线程执行,会比较耗时,为了提高效率,我们需要通过多线程异步方式来提高效率;

比方说大批量数据的同步方案,只能通过批量查询+多线程+异步的方式来完成。才能更短的时间内更高效的完成任务。

public class SynchronizationData {
 

private static final Logger logger = LoggerFactory.getLogger(SynchronizationData.class);
@Autowired
private ApplicationSumaryMapper applicationSumaryMapper;//需要同步的数据表(mybatis完成)

@Autowired
private ContactPhoneMapper contactPhoneMapper;//需要插入的数据表一(mybatis完成)

@Autowired
private MiddleFieldMapper middleFieldMapper; //需要插入的数据表二(mybatis完成)

private static ExecutorService executor = Executors.newFixedThreadPool(2); //定义线程池用于多线程执行。

//需要同步总条数
private long totalNumber = 0;
//需要同步的最大进件id;
private long maxSid = 0;
//当前已经同步的sid
private long currentSid = 0;
private long currentPage = 0;
private long maxPage = 0;

public void startSynData() {

    //获取当前系统中最大的sid
    maxSid = applicationSumaryMapper.getMaxSid();
    logger.info("需要同步的最大进件id(SID)为:", maxSid);
    
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值