在函数间不能传递32个以上参数的疑难问题
作者:水晶 发布时间:2008-12-31 13:31:00
本文中的示例主要是解决在函数间不能传递多个(32个以上)参数的问题,解题的具体思路就是采用记录类型作为函数的输入和返回值,所以我们需要先定义一个视图,把它作为一个结构类型,函数的输入和输出就用它作为数据类型,但是在研究过程中存在record类型不能直接作为函数的参数传入参数,所以我们需要建立一个函数test_rec3,这个函数的主要功能就是返回一个test_view形式的record结构,这样在 test_rec2中将test_rec3的结果作为参数传入,可以避免在直接传入record类型变量的时候的错误,在test_rec2中,又可以给其他传入参数的其他属性赋值,这样可以多建几个类似test_rec2的函数,完成对传入阐述的赋值,最后在test_rec1中赋值给一个record 类型变量,这样test_rec2的返回值可以作为其他函数输入,而且这个输入的变量相当于一个结构,虽然它是一个变量,但却包含了多个变量的信息,从而实现了向一个函数中输入操作系统限制数量的参数(32个) 。
create view test_view (p1,p2) as select cast(null as int),cast(null asint)
create or replace function test_rec1(int,int) returns test_view as
'
declare
view_rec test_view%rowtype ;
view_rec1 test_view%rowtype ;
begin
view_rec.p1 = 2;
view_rec.p2 = 3;
select * into view_rec1 from test_rec2( test_rec3($1),$2);
return view_rec1;
end;'language 'plpgsql';
create or replace function test_rec2(test_view,int) returns test_view as
'
declare
view_return alias for $1;
begin
view_return.p2 = $2;
return view_return;
end;'language 'plpgsql';
create or replace function test_rec3(int) returns test_view as
'
declare
view_return test_view%rowtype;
begin
view_return.p1 = $1;
view_return.p2 =0;
return view_return;
end;'language 'plpgsql';


猜你喜欢
- 一、概述网络爬虫(Web crawler),又称为网络蜘蛛(Web spider)或网络机器人(Web robot),主要用来爬取目标网站内
- 本文默认你的开发环境.数据库已经安装好想用使用数据库.我们需要现在pom文件中添加相应的依赖pom.xml<?xml version=
- 一、TCP1、tcp服务器创建#创建服务器from socket import *from time import ctime #导入cti
- 加上这句代码:print torch.cuda.is_available()判断完毕!说说在pytorch中如何查看gpu信息吧~为什么将数
- <?php session_start(); $_SESSION['username']="zhuzhao&
- 目录一、需求二、实现连接Mysql并执行查询语句三、写一个错误处理函数四、设置二级缓存一、需求实现二级缓存程序运行起来后提示:“请输入命令:
- 引言:本人从小白自学python,为了测试基础学习效果,增加一定的促进,想通过参加全国计算机等级考试二级python来检验基础学习情况。在学
- 在制作登录页面时学习了TK弹窗的输入文本框的使用,下面让我们一起来学习一下TK弹窗中的输入框及文本框的使用方法吧!输入框要想制作一个输入弹窗
- 继续Mootools的扩展,适用于Mootools 1.1及1.2,这次在Element扩展了两个非常简单的方法,一个用来获取
- --BEGIN DISTRIBUTED TRANSACTION [transactionname]--标志一个由分布式事务处理协调器MSDT
- 平时写的一些 Python 的代码,需要在其他模块里面复用。最粗狂的方法就是直接 copy 过去。但这种方式太麻烦,copy 一堆代码,导致
- Go GRPC 入门1,安装包grpcgolang-grpc 包提供了 gRPC 相关的代码库,通过这个库我们可以创建 gRPC 服务或客户
- 一、argparse简介argparse 是 python 自带的命令行参数解析包,可以用来方便的服务命令行参数,使用之前需要先导入包 im
- 本文实例为大家分享了python tkinter实现屏保程序的具体代码,供大家参考,具体内容如下该脚本摘录自:2014年辛星tkinter教
- 1.简介torch.autograd.Variable是Autograd的核心类,它封装了Tensor,并整合了反向传播的相关实现Varia
- 前言当我们使用Python完成自己的原创的工具时,比如:端口扫描、弱口令爆破等。你是否想过添加自己的Logo,以及简要的帮助信息?如下:Sq
- 本文实例讲述了PHP设计模式:装饰器模式Decorator。分享给大家供大家参考,具体如下:1. 概述  
- 函数声明为:func Replace(s, old, new string, n int) string官方描述为:返回将s中前n个不重叠o
- 本文介绍使用python+pyqt5开发桌面程序的一个可视化UI视图布局一、环境包的安装1、如果还不知道虚拟环境的可以参考,或者直接使用pi
- 导包效果展示以下截图显示的撤回消息类型依次是文字消息、微信自带表情、图片、语音、定位地图、名片、公众号文章、音乐、视频。有群里撤回的,也有个