DB2中的EXECUTE IMMEDIATE和EXECUTE WITH PREPARE有什么区别?
EXECUTEIMMEDIATE和EXECUTEPREPARE是动态SQL的形式。在立即执行EXECUTE的情况下,我们可以在主机变量中给出SQL语句,然后在EXECUTEIMMEDIATE中传递此主机变量。
下面的示例演示了这些形式。
示例
01 WS-SQL-DECLARE 05 WS-SQL-LEN PIC S9(04) COMP. 05 WS-SQL-QUERY PIC X(70). MOVE +80 TO WS-SQL-LEN MOVE “UPDATE ORDERS SET ORDER_PAID = ‘YES’ WHERE ORDER_DATE = ‘14-08-2020’” TO WS-SQL-QUERY EXEC SQL EXECUTE IMMEDIATE :WS-SQL-DECLARE END-EXEC
如果是EXECUTEPREPARE,则首先准备SQL语句,然后执行。我们可以使用这种形式的动态SQL,如下所示。
示例
01 WS-SQL-DECLARE 05 WS-SQL-LEN PIC S9(04) COMP. 05 WS-SQL-QUERY PIC X(70). MOVE +80 TO WS-SQL-LEN MOVE “UPDATE ORDERS SET ORDER_PAID = ‘YES’ WHERE ORDER_DATE = ‘14-08-2020’” TO WS-SQL-QUERY EXEC SQL PREPARE RUNFORM FROM :WS-SQL-DECLARE END-EXEC EXEC SQL EXECUTE RUNFORM END-EXEC
热门推荐
10 服装超市开业祝福语简短
11 生物老师高考祝福语简短
12 家人毕业祝福语简短励志
13 所有的新年祝福语简短
14 教培生日祝福语简短
15 新年给大哥祝福语简短
16 新年祝福语简短 经典短句
17 重逢时的祝福语简短
18 公司新年祝福语简短的