Java批量插入MySQL是指在Java应用程序中,通过JDBC(Java Database Connectivity)API一次性向MySQL数据库插入多条记录,以提高数据插入的效率。
Java批量插入MySQL主要有以下几种方式:
addBatch()
和executeBatch()
方法进行批量插入。批量插入MySQL适用于以下场景:
以下是一个使用PreparedStatement
进行批量插入的示例代码:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.List;
public class BatchInsertExample {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/mydatabase";
String user = "username";
String password = "password";
try (Connection conn = DriverManager.getConnection(url, user, password)) {
conn.setAutoCommit(false); // 关闭自动提交
String sql = "INSERT INTO users (name, email) VALUES (?, ?)";
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
List<User> users = getUsers(); // 假设这是一个获取用户列表的方法
for (User user : users) {
pstmt.setString(1, user.getName());
pstmt.setString(2, user.getEmail());
pstmt.addBatch(); // 添加到批处理
}
pstmt.executeBatch(); // 执行批处理
conn.commit(); // 提交事务
} catch (SQLException e) {
conn.rollback(); // 回滚事务
e.printStackTrace();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
private static List<User> getUsers() {
// 假设这是一个获取用户列表的方法
return List.of(
new User("Alice", "alice@example.com"),
new User("Bob", "bob@example.com")
);
}
}
class User {
private String name;
private String email;
public User(String name, String email) {
this.name = name;
this.email = email;
}
public String getName() {
return name;
}
public String getEmail() {
return email;
}
}
通过以上内容,您应该对Java批量插入MySQL有了全面的了解,并能够解决常见的相关问题。
没有搜到相关的文章