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

时间:2024-01-23 20:08:58

执行预编译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),如果一次绑定数据过大,可能因报文过长导致异常。因此PrepareStatement设置绑定参数时需要注意评估和控制绑定数据的大小,避免出现超出报文上限要求的现象。

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

    1
    int rowcount = pstmt.executeUpdate();
    

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

    1
    pstmt.close();
    

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