使用JDBC从Java使用Oracle数据库解析器

时间:2013-12-23 13:55:17

标签: java oracle jdbc

我正在用Java编写一个工具,它将语句提交给数据库,这些数据库稍后运行。我正在使用JDBC连接到数据库。该数据库是Oracle 10g。

在将语句写入数据库之前,我想解析它们以检查它们何时运行以后不会出现问题。我考虑使用ANTLR解决方案,因为有可用的语法,但当然如果我有数据库的连接,必须有一种方法来使用解析器中内置的数据库。

基本上我的问题是:

有没有办法使用JDBC我可以调用数据库解析器传递一个SQL语句,它会给我一些反馈,告诉我它是否成功或是否有任何错误消息?

非常感谢任何帮助, 非常感谢。

编辑:

使用connection.prepareStatement似乎不起作用,例如此输出已成功解析!

String statement = "WHERE DISTINCT SELECT";
    Connection connection;
    try {
        connection = this.controller.getDataSource().getConnection();
        connection.prepareStatement(statement);
        connection.close();
        mainPanel.setPositiveText("Parsed Successfully!");
    } catch (Exception e) {
        mainPanel.setNegativeText("ERROR: " + e.getMessage());
        return;
    }

我使用的灵魂如下:

    String statement = "DECLARE "
            + "myNumber NUMBER; "
            + "BEGIN "
            + "myNumber := SYS.dbms_sql.open_cursor; "
            + "SYS.DBMS_SQL.PARSE(myNumber, '" + text + "', SYS.DBMS_SQL.NATIVE); "
            + "END;";

    Connection connection;
    try {
        connection = this.controller.getDataSource().getConnection();
        PreparedStatement preparedStatement = connection.prepareStatement(statement);
        preparedStatement.execute();
        connection.close();
        mainPanel.setPositiveText("Parsed Successfully!");
    } catch (Exception e) {
        mainPanel.setNegativeText("ERROR: " + e.getMessage());
        System.out.println(e.getMessage());
        return;
    }

2 个答案:

答案 0 :(得分:7)

我不知道你到底想要什么,但也许你想尝试使用包DBMS_SQL和它的方法PARSE。这仅适用于 DML 语句。这就是Oracle SQL Developer所做的。

parser也可用于DML语句。对于PL / SQL,它需要一些调整。据我所知,没有人花足够的时间为Oracle的DDL创建一个真正完全验证的解析器。

Here是我如何使用它的一个例子:

declare 
 l_cursor number := dbms_sql.open_cursor; 
 l_offset number := -1 ; 
begin 
  begin 
    dbms_sql.parse( l_cursor, :st, dbms_sql.native ); 
  exception when others then
   l_offset := dbms_sql.last_error_position;
  end;
dbms_sql.close_cursor( l_cursor );
  :off := l_offset;
end;

只需执行此块即可。传递一个类型为VARCHAR2(String)的输入参数(最大32KB)和一个输出参数NUMBER。

答案 1 :(得分:1)

在不执行查询的情况下,您无法得到反馈(或结果集,关于它。Connection.preparedStatement只返回一个PreparedStatement对象,这只是一个处理程序。

PreparedStatement.executeQuery()只是实际执行查询的内容,推送到数据库。