当前位置:Gxlcms > 数据库问题 > PL/SQL相关的数据字典

PL/SQL相关的数据字典

时间:2021-07-01 10:21:17 帮助过:22人阅读

object_name FROM user_objects WHERE object_type = ‘TABLE‘ ORDER BY object_name;

2)显示所有失效的对象名:

SELECT object_type, object_name 
FROM user_objects 
WHERE status = ‘INVALID‘ 
ORDER BY object_type, object_name; 

3)显示所有今天修改的对象:

SELECT object_type, object_name, 
last_ddl_time 
FROM user_objects 
WHERE last_ddl_time >= TRUNC (SYSDATE) 
ORDER BY object_type, object_name 

3、搜索和展现源代码 USER_SOURCE
列介绍:
NAME: Name of the object

TYPE: Type of the object (ranging from PL/SQL program units to Java source and trigger source)

LINE: Number of the line of the source code

TEXT: Text of the source code

例如: 我需要改变包SALES_MGR中CALC_TOTALS过程的参数列表。我想找到哪些地方对该过程进行了调用。

SELECT name, line, text 
FROM user_source 
WHERE UPPER (text) 
LIKE ‘%SALES_MGR.CALC_TOTALS%‘ 
ORDER BY name, line 

当然,这个查询可能连注释也查出来,还有就是不符合LIKE格式的字符串将无法检索出来,例如:
SALES_MGR.
CALC_TOTALS

那么假设,我们的代码都是比较标准的,这个查询还是做了一个不错的工作。
另外,对于11g而言,你可以使用PL/Scope特性。

4、存储代码的编译设置 USER_PLSQL_OBJECT_SETTINGS
PLSQL_OPTIMIZE_LEVEL: 编译对象的优化级别

PLSQL_CODE_TYPE: 对象的编译模式

PLSQL_DEBUG: Whether or not the object was compiled for debugging 对象是否为调试而编译

PLSQL_WARNINGS: 编译对象的编译警告设置

NLS_LENGTH_SEMANTICS: NLS length semantics that were used to compile the object 编译对象的语义长度设置

找出所有没有采用有效编译时优化的程序单元:

SELECT name
FROM user_plsql_object_settings
WHERE plsql_optimize_level < 2

0级表示未采取任何优化。1表示最低限度的优化。2者都不应该存在于生产环境。

找出那些禁用了编译时警告的程序。

SELECT name, plsql_warnings 
FROM user_plsql_object_settings 
WHERE plsql_warnings LIKE ‘%DISABLE%‘; 

5、关于过程和函数的详细信息 USER_PROCEDURES
AUTHID: Shows whether a procedure or a function is defined as an invoker rights (CURRENT_USER) or definer rights (DEFINER) program unit 调用者权限或是定义者权限

DETERMINISTIC: Set to YES if the function is defined to be deterministic, which theoretically means that the value returned by the function is determined completely by the function’s argument values 是否确定性

PIPELINED: Set to YES if the function is defined as a pipelined function, which means that it can be executed in parallel as part of a parallel query 是否管道函数

OVERLOAD: Set to a positive number if this subprogram is overloaded, which means that there are at least two subprograms with this name in the same package 是否重载

找出所有运行在调用者权限下的过程和函数

SELECT object_name 
, procedure_name 
FROM user_procedures 
WHERE authid = ‘CURRENT_USER‘ 
ORDER BY object_name, procedure_name 

显示所有声明为确定性的函数:

SELECT object_name 
, procedure_name 
FROM user_procedures 
WHERE deterministic = ‘YES‘ 
ORDER BY object_name, procedure_name 

6、分析和修改触发器状态 USER_TRIGGERS
TRIGGER_NAME: The name of the trigger

TRIGGER_TYPE: A string that shows if this is a BEFORE or AFTER trigger and whether it is a row- or statement-level trigger (in a trigger that is fired before an INSERT statement, for example, the value of this column is BEFORE STATEMENT)

TRIGGERING_EVENT: The type of SQL operation—such as INSERT, INSERT OR UPDATE, DELETE OR UPDATE—that will cause the trigger to fire

TABLE_NAME: The name of the table on which the trigger is defined

STATUS: The status of the trigger—ENABLED or DISABLED

WHEN_CLAUSE: An optional clause you can use to avoid unnecessary execution of the trigger body

TRIGGER_BODY: The code executed when the trigger fires

找出所有已禁用的触发器:


SELECT * 
FROM user_triggers 
WHERE status = ‘DISABLED‘ 

找出所有定义在EMPLOYEES表上的行级触发器:

SELECT * 
FROM user_triggers 
WHERE table_name = ‘EMPLOYEES‘ 
AND trigger_type LIKE ‘%EACH ROW‘ 

Find all triggers that fire when an UPDATE operation is performed:
找出所有包含update操作触发的触发器

SELECT * 
FROM user_triggers 
WHERE triggering_event LIKE ‘%UPDATE%‘ 

7、对象依赖分析 USER_DEPENDENCIES
NAME: Name of the object

TYPE: Type of the object

REFERENCED_OWNER: Owner of the referenced object 被引用对象的所有者

REFERENCED_NAME: Name of the referenced object 被引用对象的名称

REFERENCED_TYPE: Type of the referenced object 被引用对象的类型

找出所有依赖于EMPLOYEES表的对象:

SELECT type, name 
FROM user_dependencies 
WHERE referenced_name = ‘EMPLOYEES‘ 
ORDER BY type, name 

找出当前模式下ORDER_MGR包依赖的所有对象

SELECT referenced_type 
, referenced_name 
FROM user_dependencies 
WHERE name = ‘ORDER_MGR‘ 
AND referenced_owner = USER 
ORDER BY referenced_type, 
referenced_name 

8、分析参数信息 USER_ARGUMENTS
OBJECT_NAME: The name of the procedure or function

PACKAGE_NAME: The name of the package in which the procedure or function is defined

ARGUMENT_NAME: The name of the argument

POSITION: The position of the argument in the parameter list (if 0, this is the RETURN clause of a function)

IN_OUT: The mode of the argument—IN, OUT, or IN OUT

DATA_TYPE: The datatype of the argument

DATA_LEVEL: The nesting depth of the argument for composite types (for example, if one of your arguments’ datatypes is a record, USER_ARGUMENTS will have a row for this argument with a DATA_LEVEL of 0 and then a row for each field in the record with a DATA_LEVEL of 1)

1)找出所有包含LONG参数的程序

SELECT object_name 
, package_name 
, argument_name 
FROM user_arguments 
WHERE data_type = ‘LONG‘ 
; 

2)找出所有带有OUT或IN OUT参数的函数。这个地方要注意一下:有经验的编程专家都会告诉我们不要在函数中仅使用IN 参数,
原因是带有OUT 和 IN OUT参数函数不能在SQL中被调用,并且不能用在函数索引中。如果你需要函数返回多块信息,那么请使用
一个存储过程或返回一个RECORD类型。下面的例子找出了违反这个条件的函数:

SELECT ua.object_name, 
2 ua.package_name, 
3 ua.argument_name, 
4 ua.in_out 
5 FROM (SELECT * 
6 FROM user_arguments 
7 WHERE position = 0) funcs, 
8 user_arguments ua 
9 WHERE ua.in_out IN (‘OUT‘, ‘IN OUT‘) 
10 AND ua.position > 0 
11 AND ua.data_level = 0 
12 AND funcs.object_name = ua.object_name 
13 AND funcs.package_name = ua.package_name 
14 AND ( funcs.overload = ua.overload 
15 OR (funcs.overload IS NULL 
16 AND ua.overload IS NULL)); 

9 总结:这儿有座金矿
This article merely scratches the surface of the application information that can be mined from the data dictionary views in Oracle Database. PL/SQL editors such as Oracle SQL Developer provide user interfaces to many of these views, making it easier to browse their contents.

本文只是拂去了可以从Oracle数据字典视图中挖掘出的应用信息的一层表面。PL/SQL编辑器例如Oracle SQL Developer对很多
视图提供了用户接口,从而更容易的浏览它们的内容。

版权声明:本文为博主原创文章,未经博主允许不得转载。

PL/SQL相关的数据字典

标签:数据字典   plsql   

人气教程排行