使用Oracle批量写入多条数据(oracle写入多条数据)


使用Oracle批量写入多条数据

在Oracle数据库中,如果需要一次性插入多条数据,可以使用批量写入的方式,这样可以大幅度提高插入数据的效率。使用批量写入方式,需要使用JDBC的批量插入功能。

下面是一个使用JDBC批量插入Oracle数据库的例子:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.ArrayList;
public class BatchInsertOracle {
public static void mn(String[] args) {
String driver = "oracle.jdbc.driver.OracleDriver";
String url = "jdbc:oracle:thin:@localhost:1521:XE";
String user = "username";
String password = "password";
Connection conn = null;
PreparedStatement pstmt = null;
ArrayList userList = new ArrayList();
userList.add(new User("张三", 20, "男"));
userList.add(new User("李四", 21, "男"));
userList.add(new User("王五", 22, "男"));

try {
Class.forName(driver);
conn = DriverManager.getConnection(url, user, password);

String sql = "insert into user(name, age, gender) values(?, ?, ?)";
pstmt = conn.prepareStatement(sql);
for (User user : userList) {
pstmt.setString(1, user.getName());
pstmt.setInt(2, user.getAge());
pstmt.setString(3, user.getGender());
pstmt.addBatch();
}
pstmt.executeBatch();

} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally {
try {
if (pstmt != null) {
pstmt.close();
}
if (conn != null) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}

static class User {
private String name;
private int age;
private String gender;
public User(String name, int age, String gender) {
super();
this.name = name;
this.age = age;
this.gender = gender;
}
public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public int getAge() {
return age;
}

public void setAge(int age) {
this.age = age;
}

public String getGender() {
return gender;
}

public void setGender(String gender) {
this.gender = gender;
}

}
}

上面是一个示例代码,其中使用了ArrayList保存需要批量插入的数据,然后使用JDBC的批量插入功能insert into … values(?, ?, ?)语句添加的数据将自动批量插入到数据库中。

需要注意的是,JDBC的批量插入只能用于插入数据,而无法用于更新或删除数据。

在实际使用中,批量插入可以大幅度提高程序的执行效率。特别是在需要一次性插入大量数据的情况下,批量插入的优势更加明显。