更新时间:2024-06-03 GMT+08:00

DBE_PLDEVELOPER.gs_source

用于记录PL/SQL对象(存储过程、函数、包、包体)编译相关信息,如表1所示。

打开plsql_show_all_error参数后,会把成功或失败的PL/SQL对象编译信息记录在此表中,如果关闭plsql_show_all_error参数则只会将正确的编译相关信息插入此表中。

  1. gs_source表中只记录用户定义的原始对象语句,即使用户使用了ALTER改变了创建的SCHEMA或者名字,gs_source表中的信息也不会发生变化,如果用户更改了对象的SCHEMA或者名字,会导致用户在删除对象后,对象仍存在于gs_source表中。
  2. gs_source表中的owner指创建的用户,不是用户创建存储过程或者package时指定的用户。
  3. 数据库默认情况下没有对gs_source表中设置行级访问控制,如果用户想使用数据库隔离性特性,请参考以下语句,自行添加行级访问控制。
    ALTER TABLE dbe_pldeveloper.gs_source ENABLE ROW LEVEL SECURITY;
    CREATE ROW LEVEL SECURITY POLICY all_data_rls ON dbe_pldeveloper.gs_source USING(owner = (select oid from pg_roles where rolname=current_user));
表1 DBE_PLDEVELOPER.gs_source字段

名称

类型

描述

id

oid

对象id。

owner

bigint

对象创建用户id。

nspid

oid

对象的模式id。

name

name

对象名。

type

text

对象类型(procedure/function/package/package body)。

status

boolean

是否创建成功。

src

text

对象创建的原始语句。