5

我试图在与 Oracle 数据库通信的应用程序中引用列名来排序查询。我想使用绑定变量,以便我可以动态更改查询的顺序。

我遇到的问题是数据库似乎忽略了按列排序。

有谁知道是否有通过绑定变量引用数据库列的特定方法,或者是否有可能?

例如我的查询是

SELECT * FROM PERSON ORDER BY :1

:1将绑定到哪里PERSON.NAME)查询未按字母顺序返回结果,我担心数据库将其解释为:-

SELECT * FROM PERSON ORDER BY 'PERSON.NAME' 

这显然行不通。

任何建议都非常感谢。

4

3 回答 3

8

不可以。您不能将绑定变量用于表名或列名。

需要此信息来创建执行计划。例如,如果不知道您要订购什么,就不可能弄清楚要使用什么索引。

当您的程序创建列名时,您必须直接将列名插入到 SQL 语句中,而不是绑定变量。假设您对 SQL 注入采取了预防措施,那么这没有任何不利之处。

更新:如果你真的想跳过篮球,你可能会做类似的事情

order by decode(?, 'colA', colA, 'colB', colB)

但这很愚蠢。而且慢。不。

于 2009-03-04T10:46:27.813 回答
2

当您使用 JDBC 时。您可以将代码重写为没有绑定变量的内容。这样,您还可以动态更改 order-by,例如:

String query = "SELECT * FROM PERS ";
if (condition1){
  query = query+ " order by name ";
// insert more if/else or case statements
} else {
  query = query+ " order by other_column ";
}
Statement select = conn.createStatement();
ResultSet result = select.executeQuery(query);

甚至:

String columnName = getColumnName(input);
Statement select = conn.createStatement();
ResultSet result = select.executeQuery("SELECT * FROM PERS ORDER BY "+columnName);
于 2009-03-04T15:54:25.653 回答
0
ResultSet result = select.executeQuery(
    "SELECT * FROM PERS ORDER BY " + columnName
);

将始终是数据库的语句。
这意味着,就像 Thilo 已经解释的那样,不可能“重新排序”已经绑定、计算、准备、解析的语句。在您的应用程序中一遍又一遍地使用此结果集时,唯一会随着时间变化的是呈现的顺序,请尝试在您的客户端代码中对结果集进行排序。
否则,动态 SQL 很好,但会占用大量空间。

于 2009-03-05T07:23:12.440 回答