plsql函数返回数组集合例子

 1 create or replace type t_test as object(
 2 id integer,
 3 rq date,
 4 mc varchar2(60)
 5 );
 6
 7 create or replace type t_test_table as table of t_test;
 8
 9 create or replace function f_test_array(n in number default null) return t_test_table
10 as
11 v_test t_test_table := t_test_table();
12 begin
13 for i in 1 .. nvl(n,100) loop
14 v_test.extend();
15 v_test(v_test.count) := t_test(i,sysdate,‘mc‘||i);
16 end loop;
17 return v_test;
18 end f_test_array;
19
20
21 select * from table(f_test_array(10));
时间: 2024-08-29 07:46:21

plsql函数返回数组集合例子的相关文章

通过函数返回数组

C语言中,一个函数是不能直接返回一个集合类型的,但是我们可以返回一个数组地址,需要注意的是C语言不能返回局部变量(local variable)的地址,所以我们要在函数中将其定义为静态变量(static variable). #include<stdio.h> int *get_arr(); int main() { int *arr = get_arr(); int i = 0; for(; i<3; i++) { printf("%d\t", *(arr+i));

shell 函数 返回数组

shell 函数 返回数组,布布扣,bubuko.com

C语言中函数返回数组

#include "stdio.h"/*int* set(int a,int *c){ int *b; b=malloc(sizeof(int)*3); c[0]=a; c[1]=1+a; c[2]=2+a; b[0]=13; b[1]=14; b[2]=15; return b;}*/char *set(void){ char *buf; buf=malloc(sizeof(char)*3);//创建内存区 buf[0]=0x30; buf[1]=0x31; buf[2]=0x32;

浅谈Oracle函数返回Table集合

在调用Oracle函数时为了让PL/SQL 函数返回数据的多个行,必须通过返回一个 REF CURSOR 或一个数据集合来完成.REF CURSOR 的这种情况局限于可以从查询中选择的数据,而整个集合在可以返回前,必须进行具体化. 9i 通过引入Oracle函数中的管道化表函数纠正了后一种情况.表函数是返回整个行的集(通常作为一个集合)的函数,可以直接从 SQL 语句中进行查询,就好像它是一个真正的数据库表一样.管道化表函数与之相似,但是它像在构建时一样返回数据,而不是一次全部返回.管道化表函数

从函数返回数组

1 char* vector_advance(char* val) 大部分人都遇到过上面的函数,最大的问题就是资源由谁释放? 再看一个函数 1 char (&vector_advance(char (&var)[4]))[4] 这个函数的意思是,vector_advance是函数名,接收一个包含4个元素的数组,返回一个包含4个元素的数组,这个写法确实有点怪异, 换个易懂的写法 1 typedef mychar char[4]; 2 mychar& vector_advance(my

C++ 从函数返回数组

C++ 不允许返回一个完整的数组作为函数的参数.但是,您可以通过指定不带索引的数组名来返回一个指向数组的指针. 如果您想要从函数返回一个一维数组,您必须声明一个返回指针的函数,如下: int * myFunction() { . . . } 另外,C++ 不支持在函数外返回局部变量的地址,除非定义局部变量为 static 变量. 现在,让我们来看下面的函数,它会生成 10 个随机数,并使用数组来返回它们,具体如下: #include <iostream> #include <cstdli

c++怎样让函数返回数组

这个问题属于非常初级的问题,但是对于初学不知道的人可能会比较头疼.C++中函数是不能直接返回一个数组的,但是数组其实就是指针,所以可以让函数返回指针来实现.比如一个矩阵相乘的函数,很容易地我们就写成: 1 #include <iostream> 2 3 using namespace std; 4 5 void MultMatrix(float M[4], float A[4], float B[4]) 6 { 7 M[0] = A[0]*B[0] + A[1]*B[2]; 8 M[1] =

函数返回数组

这个问题属于非常初级的问题,但是对于初学不知道的人可能会比较头疼.C++中函数是不能直接返回一个数组的,但是数组其实就是指针,所以可以让函数返回指针来实现.比如一个矩阵相乘的函数,很容易地我们就写成: #include <iostream> using namespace std; float* MultMatrix(float A[4], float B[4]) { float M[4]; M[0] = A[0]*B[0] + A[1]*B[2]; M[1] = A[0]*B[1] + A[

C++ 函数返回数组指针的问题

提醒一下:int *func(){int a[10] = {5};return a;}是非法的,因为 a 是局部变量,被申请在系统栈中,局部变量在函数返回后会被销毁,于是你返回的指针指向的是一段已经被系统回收的内存,这样的访问是非法的.int *func(){int *a = new int[10];a[0] = 5;return a;}是合法的,通过new运算符申请的一段内存是在系统堆上的,其销毁不受系统控制,而由程序员控制,所以如果在外部有int *ret = func(),将 ret 使用