gpt4 book ai didi

oracle - 是否可以通过 Oracle 中的绑定(bind)变量引用列名?

转载 作者:行者123 更新时间:2023-12-04 23:11:17 25 4
gpt4 key购买 nike

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

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

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

例如我的查询是

SELECT * FROM PERSON ORDER BY :1

(其中 :1 将绑定(bind)到 PERSON.NAME )
查询未按字母顺序返回结果,我担心数据库将其解释为:-
SELECT * FROM PERSON ORDER BY 'PERSON.NAME' 

这显然行不通。

任何建议都非常感谢。

最佳答案

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

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

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

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

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

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

关于oracle - 是否可以通过 Oracle 中的绑定(bind)变量引用列名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/610056/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com