云数据库 GaussDB-执行SQL语句:执行预编译SQL语句

时间:2025-02-12 15:09:14

执行预编译SQL语句

预编译语句是只编译和优化一次,然后可以通过设置不同的参数值多次使用。由于已经预先编译好,后续使用会减少执行时间。因此,如果多次执行一条语句,请选择使用预编译语句。可以按以下步骤执行:

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

    1
    PreparedStatement pstmt = con.prepareStatement("UPDATE customer_t1 SET c_customer_name = ? WHERE c_customer_sk = 1");

  2. 调用PreparedStatement的setShort设置参数。

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

    PrepareStatement设置绑定参数后,最终会构建成一个B报文(或U报文)在下一步执行SQL语句时发给服务端。但是B/U报文有最大长度限制(不能超过1023MB),如果一次绑定数据过大,可能因报文过长导致异常。因此在这一步需要注意评估和控制绑定数据的大小,避免超出报文上限。

  3. 调用PreparedStatement的executeUpdate方法执行预编译SQL语句。

    1
    int rowcount = pstmt.executeUpdate();

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

    1
    pstmt.close();

support.huaweicloud.com/distributed-devg-v2-gaussdb/gaussdb-12-0062.html