我正在用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;
}
答案 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()
只是实际执行查询的内容,推送到数据库。