当前位置:首页 » 存储配置 » 存储过程nvl

存储过程nvl

发布时间: 2025-08-16 01:27:06

1. oracle高手快来看看,我想写一个输出结果集的存储过程并执行

create or replace procere p_selTabSpace(v1

dba_data_files.tablespace_name%type)
as
var1 dba_data_files.tablespace_name%type;
var2 number;
var3 number;
var4 number;
begin
select a.a1 "tabSpaceName",b.b2/1024/1024 "tabSpaceSize",round((b.b2 -

a.a2) / 1024 / 1024, 2) "tabSpaceUsed",substr((b.b2 - a.a2) / b.b2, 1,

7) "tabSpaceVused" into var1,var2,
var3,var4
from
(select tablespace_name a1, sum(nvl(bytes, 0)) a2
from dba_free_space
group by tablespace_name) a,
(select tablespace_name b1, sum(bytes) b2
from dba_data_files
group by tablespace_name) b,
(select tablespace_name c1, contents c2, extent_management c3
from dba_tablespaces) c
where a.a1=UPPER(v1) and a.a1 = b.b1 and c.c1 = b.b1;
DBMS_OUTPUT.PUT_LINE('tabSpaceName is'||UPPER(VAR1)||'

'||'tabSpaceSize'||var2||' '||'tabSpaceUsed'||var3||'

'||'tabSpaceVused'||var4);
END;
--------------------------------TEST-------------------------
EXECUTE p_selTabSpace('system');

你想得到结果集是用来存放单行的数据还是存放多行的数据,如果是后者的话,单纯的select...into...这种方法是实现不了的,原因是你不可以将一列的多个结果都付给同一个变量,这也就是使用select...into...这种方式的一种局限,如果想用来存放多行结果就要向楼上说的那样使用游标或者是复合数据类型才可以。

热点内容
sql把字符串转换成日期 发布:2025-08-16 03:14:40 浏览:71
python爬虫的书籍 发布:2025-08-16 02:43:26 浏览:103
87键盘源码 发布:2025-08-16 02:15:13 浏览:845
app访问网页 发布:2025-08-16 02:14:37 浏览:856
编译之后的链接是干什么的 发布:2025-08-16 01:54:51 浏览:824
rust腐蚀服务器ip地址 发布:2025-08-16 01:53:26 浏览:266
编程代中文 发布:2025-08-16 01:47:42 浏览:709
公积金账户密码是哪里的 发布:2025-08-16 01:41:50 浏览:871
如何从iphone查看wifi密码 发布:2025-08-16 01:37:29 浏览:70
swf编译器 发布:2025-08-16 01:27:51 浏览:121