如何做一个函数来从 pl/sql 中的表中返回行类型?

Posted

技术标签:

【中文标题】如何做一个函数来从 pl/sql 中的表中返回行类型?【英文标题】:how to do a function to return row type from a table in pl/sql? 【发布时间】:2016-04-07 18:38:02 【问题描述】:

我做了这个函数,但是当我执行它时它返回一个错误!

create or replace function get_accounts
(Acc_id in Account1.account_id%Type)
return account1%rowtype
as
l_cust_record account1%rowtype;
begin
select * into l_cust_record from account1
where account_id=Acc_id;
return(l_cust_record);
end;
/

【问题讨论】:

你是如何执行它的?错误是什么? 执行 Get_Accounts(account_id);这是错误 PLS-00221: 'GET_ACCOUNTS' is not an procedure or is undefined 您使用的是 SQL Server 还是 Oracle。 Oracle 是 Pl\SQL,SQL Server 是 T-SQL 我删除了sql-server 标签,因为这显然是PL/SQL 我用的是OracleSQL Developer,我只是一个初学者,希望你能帮助我 【参考方案1】:

Oracle 设置

CREATE TABLE account1 (
 account_id INT,
 name       VARCHAR2(20)
);

INSERT INTO account1 VALUES ( 1, 'Bob' );

CREATE OR REPLACE FUNCTION get_accounts(
  Acc_id IN Account1.account_id%TYPE
) RETURN account1%ROWTYPE
AS
  l_cust_record account1%ROWTYPE;
BEGIN
  SELECT *
  INTO   l_cust_record
  FROM   account1
  WHERE  account_id = Acc_id;

  RETURN l_cust_record;
END;
/

PL/SQL 块

DECLARE
  r_acct ACCOUNT1%ROWTYPE;
BEGIN
  r_acct := get_accounts( 1 );
  DBMS_OUTPUT.PUT_LINE( r_acct.name );
END;
/

输出

Bob

【讨论】:

【参考方案2】:

要在 Oracle 中调用一个函数,您需要使用它的返回值。也就是说,您不能像调用过程那样调用它。像这样的东西会起作用:

declare
  myrow account1%rowtype;
  account_id Account1.account_id%Type := <VALID ACCOUNT ID VALUE>;
begin
  myrow := Get_Accounts(account_id); 
end;
/

【讨论】:

以上是关于如何做一个函数来从 pl/sql 中的表中返回行类型?的主要内容,如果未能解决你的问题,请参考以下文章

如何从 Oracle PL/SQL 函数中返回现有表中的记录?

将修改后的表中的游标用于相同的 PL/SQL 过程

如何使用 pl/sql 中的游标将多列数据插入包含单列的表中?

如何使用间隔 1 分钟在两个日期之间将时间序列数据生成到 Oracle PL/SQL 中的表中?

如何传递从多个表创建的 PL/SQL 游标记录?

Oracle PL/SQL:如何根据同一记录的 ID 字段返回字符串值?