当前位置:  开发笔记 > 数据库 > 正文

是否可以通过Oracle中的绑定变量引用列名?

如何解决《是否可以通过Oracle中的绑定变量引用列名?》经验,为你挑选了1个好方法。

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

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

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

例如,我的查询是

SELECT * FROM PERSON ORDER BY :1

(:1将被绑定的位置PERSON.NAME)查询不按字母顺序返回结果,我担心数据库将其解释为: -

SELECT * FROM PERSON ORDER BY 'PERSON.NAME' 

哪个显然不起作用.

任何建议都非常感谢.



1> Thilo..:

不可以.您不能对表名或列名使用绑定变量.

创建执行计划需要此信息.例如,如果不知道您想要订购什么,就无法确定要使用的索引.

您必须在程序创建时将列名直接插入到SQL语句中,而不是绑定变量.假设你采取了预防SQL注入的措施,那就没有任何缺点了.

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

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

但那真是太傻了.而且很慢.别.

推荐阅读
放ch养奶牛
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有