使用绑定变量是解决ORACLE_SQL中重编译问题的有效策略。在未使用绑定变量的情况下,语句如sprintf(sqlstr, \"insert into scott.test1 (num1, num2) values (%d,%d)\",n_var1, n_var2); EXEC SQL EXECUTE IMMEDIATE :sqlstr ; EXEC SQL COMMIT;而使用绑定变量的语句则为strcpy(sqlstr, \"insert into test (num1, num2) values (:v1, :v2)\"); EXEC SQL PREPARE sql_stmt FROM :sqlstr; EXEC SQL EXECUTE sql_stmt USING :n_var1, :n_var2; EXEC SQL COMMIT;