用jdbc在mysql数据库中插入5000条记录需要太多时间。

问题描述 投票:0回答:1

我使用jdbc,mysql-connector-java-8.0.20和xampp作为mysql服务器在数据库中插入5000条记录,我使用的是 这个环节 来测试,以下是我用

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.util.Random;

public class test {
    public static void main(String[] args) {
        try {
            Class.forName("com.mysql.jdbc.Driver");
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/sonoo", "root", "");
            // here sonoo is database name, root is username and password
            String sql = "insert into emp(name, age) values(?, ?)";
            long startTime = System.currentTimeMillis();
            for (int i = 0; i < 5000; i++) {
                PreparedStatement ps = con.prepareStatement(sql);
                Random rnd = new Random();
                int age = rnd.nextInt(60);
                byte [] name = new byte[30];
                rnd.nextBytes(name);
                ps.setString(1, name.toString());
                ps.setInt(2, age);
                ps.executeUpdate();
                System.out.println(i);
            }
            long endTime = System.currentTimeMillis();
            System.out.println("taken time: " + (endTime - startTime));
            con.close();
        } catch (Exception e) {
            System.out.println(e);
        }
    }
}

和输出是。

所需时间: 315309

java mysql jdbc xampp
1个回答
3
投票

首先,也是最简单的,准备好 PreparedStatement 曾经 前的循环。像。

PreparedStatement ps = con.prepareStatement(sql);
for (int i = 0; i < 5000; i++) {
    Random rnd = new Random();
    int age = rnd.nextInt(60);
    byte[] name = new byte[30];
    rnd.nextBytes(name);
    ps.setString(1, name.toString());
    ps.setInt(2, age);
    ps.executeUpdate();
    System.out.println(i);
}

第二,如果还是不够快,就用批处理。像。

PreparedStatement ps = con.prepareStatement(sql);
for (int i = 0; i < 5000; i++) {
    Random rnd = new Random();
    int age = rnd.nextInt(60);
    byte[] name = new byte[30];
    rnd.nextBytes(name);
    ps.setString(1, name.toString());
    ps.setInt(2, age);
    ps.addBatch();
    System.out.println(i);
}
ps.executeBatch();

另外,使用 Arrays.toString(name); (你目前正在存储一个哈希码)。

© www.soinside.com 2019 - 2024. All rights reserved.