云数据库 GaussDB-执行SQL语句:执行批处理

时间:2023-11-01 16:18:26

执行批处理

用一条预处理语句处理多条相似的数据,数据库只创建一次执行计划,节省了语句的编译和优化时间。可以按如下步骤执行:

  1. 调用Connection的prepareStatement方法创建预编译语句对象。

    12
    Connection conn = DriverManager.getConnection("url","user","password");PreparedStatement pstmt = conn.prepareStatement("INSERT INTO customer_t1 VALUES (?)");

  2. 针对每条数据都要调用setShort设置参数,以及调用addBatch确认该条设置完毕。

    12
    pstmt.setShort(1, (short)2);pstmt.addBatch();

  3. 调用PreparedStatement的executeBatch方法执行批处理。

    1
    int[] rowcount = pstmt.executeBatch();

  4. 调用PreparedStatement的close方法关闭预编译语句对象。

    1
    pstmt.close();

    在实际的批处理过程中,通常不终止批处理程序的执行,否则会降低数据库的性能。因此在批处理程序时,应该关闭自动提交功能,每几行提交一次。关闭自动提交功能的语句为: conn.setAutoCommit(false);

support.huaweicloud.com/centralized-devg-v3-opengauss/gaussdb-12-0071.html