首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle DBA_EXTENTS封装

Oracle DBA_EXTENTS封装
EN

Stack Overflow用户
提问于 2022-08-26 13:18:52
回答 1查看 38关注 0票数 0

尝试由另一个所有者在DBA_EXTENTS中找到一个对象。当我在下面输入时,它的工作原理是:

代码语言:javascript
复制
SELECT *  FROM SYS.DBA_EXTENTS TP WHERE PARTITION_NAME IS NOT NULL

这项工作。

但我正在尝试将查询保存在一个包中

代码语言:javascript
复制
 SELECT * FROM DBA_EXTENTS  WHERE SEGMENT_NAME = SEGMENT_NAME_P AND OWNER = TABLE_OWNER_P

甲骨文返回错误(662,14):PL/SQL: ORA-00942:表或透视图不存在

我也尝试过使用SYS.DBA_EXTENTS。

一揽子申报:

代码语言:javascript
复制
create or replace PACKAGE  NEW_TECH_CORE AS

MOD_NAME CONSTANT VARCHAR2(10) := 'NEW_TECH_CORE';
MOD_VER  CONSTANT VARCHAR2(10) := '1.0.0';


TYPE STORAGE_S_T IS RECORD (
   TABLE_NAME          VARCHAR2(128)
  ,PARTITION_NAME      VARCHAR2(128)
  ,SUBPARTITION_NAME   VARCHAR2(128)
);
TYPE STORAGE_S_T IS TABLE OF STORAGE_S_T;

FUNCTION STORAGE_S (
  DATASTORE_ID VARCHAR2,
  SEGMENT_TYPE VARCHAR2,
  SHOW_EMPTY_SEGMENTS NUMBER := 0,
  VIEW_LEVEL VARCHAR2 := 'PARTITION'
) RETURN STORAGE_S_TAB PIPELINED;


END;
EN

回答 1

Stack Overflow用户

发布于 2022-08-26 13:40:17

在oracle中的可执行块中不能有查询。触发器,程序,包,功能,匿名,无论如何。您不能只在BEGINEND之间进行查询。您必须有游标或INTO

代码语言:javascript
复制
begin
    SELECT * FROM .....  -- <-- NOT ALLOWED
end;

这会起作用的

代码语言:javascript
复制
declare
    vA number(10);
begin
    SELECT a INTO  vA FROM .....  -- <-- ALLOWED
end;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73501644

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档