sql - 有没有办法在不执行未知数据库查询的情况下获取类型/名称?

标签 sql database oracle plsql

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

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

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

最佳答案

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

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

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

关于sql - 有没有办法在不执行未知数据库查询的情况下获取类型/名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/163389/

相关文章:

python - 跨多个表搜索(最佳实践)

sql - 将两个表合并为一个表,两个表都具有不同的 where 子句

php - 选择具有多个条件(MAX)的MySQL

c# - 从mysql数据库获取表来填充datalist

Django View 返回过时的数据,在服务器重新启动后修复

Oracle - select 语句中的动态列名

mysql - 为mysql中的out参数分配变量值

.net - 如何从类型化数据集中删除一行并将其保存到数据库中?

sql - 如何使用一个表属性或其值作为对另一个表属性的约束

oracle - 生产环境中的DB Link可能会出现哪些问题?