繁体   English   中英

Oracle-在查询中使用列名

[英]Oracle - Use Column Names IN a Query

我知道如何从oracle sql中的表中获取column_names。

我的问题是,是否可以在查询中实际使用这些column_names?

我可以得到像这样的列名:

SELECT column_name FROM user_tab_cols
WHERE table_name = 'MY_TABLE'

但是它只返回我无法执行的列名列表。

可以在查询中使用那些吗?

我需要查询表中的一堆列,并且需要动态获取列名,因此它们不会在其中硬编码。

有小费吗?

您不能仅使用原始SQL来执行此操作,必须使用PL / SQL。

因此,您必须使用存储过程并执行类似的操作:

SELECT 'SELECT '||LISTAGG(COLUMN_NAME,',')||' FROM /* your condition hew */' INTO myQuery FROM USER_TAB_COLS WHERE table_name = 'OFFER';

然后使用OPEN ... LOOP来检索您的数据。

这只是一个建议,我发现它非常复杂!

您将必须创建动态sql语句,并在生成的sql语句上使用EXECUTE IMMEDIATE调用。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM