4

我有一个 Web 应用程序,用户可以在其中输入任意 sql 查询以供以后进行批处理。我们想要验证查询的语法而不实际执行它。有些查询会花费很长时间,这就是我们不想执行它们的原因。我正在使用 Oracle 的 dbms_sql.parse 来执行此操作。

但是,我现在有一种情况,我需要知道结果集列的数量和类型。有没有办法在不实际执行查询的情况下做到这一点?也就是说,让 Oracle 解析查询并告诉我在实际执行查询时将返回什么结果数据类型/名称?我正在使用 Oracle 10g,它是一个 Java 1.5/Servlet 2.4 应用程序。

编辑:输入查询的用户已经是数据库上的用户。他们使用他们的数据库凭据对我的应用程序进行身份验证,并使用这些凭据执行查询。因此,他们无法输入任何仅通过连接 sqlplus 无法运行的查询。

4

2 回答 2

7

您应该能够准备 SQL 查询来验证语法并获取结果集元数据。准备查询不应该执行它。

import java.sql.*;
. . .
Connection conn;
. . .
PreparedStatement ps = conn.prepareStatement("SELECT * FROM foo");
ResultSetMetadata rsmd = ps.getMetaData();
int numberOfColumns = rsmd.getColumnCount();

然后,您可以获得有关结果集每一列的元数据。

于 2008-10-02T17:11:25.287 回答
4

如果您想通过 pl/sql 严格执行此操作,则可以执行以下操作:

DECLARE 
  lv_stat varchar2(100) := 'select blah blah blah';
  lv_cur INTEGER;
  lv_col_cnt INTEGER;
  lv_desc DBMS_SQL.desc_tab;
BEGIN
  DBMS_SQL.parse(lv_cur,lv_stat,DBMS_SQL.NATIVE);
  DBMS_SQL.describe_columns(lv_cur,lv_col_cnt,lv_desc);
  FOR ndx in lv_desc.FIRST .. lv_desc.LAST LOOP
    DBMS_OUTPUT.PUT_LINE(lv_desc(ndx).col_name ||' '||lv_desc(ndx).col_type);
  END LOOP;
END;

DBMS_SQL.desc_tab 包含几乎所有您需要了解的有关列的信息。

于 2009-01-16T12:53:07.740 回答