如何将select函数定义为查询?

How to select function definitions as a query?

我想select PL/SQL 定义架构中的所有函数作为查询。原因是我想查询我的所有函数以获取特定文本。

我可以为这样的视图执行此操作:

select * from all_views

但是,我不确定如何使用函数执行此操作。

可以做到吗?

要列出所有函数,可以查询the ALL_OBJECTS dictionary view :

SELECT * FROM all_objects WHERE object_type = 'FUNCTION';

这将为您提供当前用户可用的所有功能(DBA_OBJECTS 列出数据库中的所有对象)。

然后,您可以从视图中检索函数的文本源 ALL_SOURCE :

SELECT o.object_name, s.line, s.text 
FROM all_objects o
INNER JOIN all_source s 
    ON s.name = o.object_name AND s.type = o.object_type AND s.owner = o.owner
WHERE o.object_type = 'FUNCTION';