如何从函数返回的 table 中获取单独的列?

How to get individual columns from table returned from a function?

我正在尝试使用 returns table.

创建一个函数
CREATE  FUNCTION karta_pacjenta(pe VARCHAR(11))
  RETURNS TABLE('data' DATE,'imie' TEXT, 'nazwisko' TEXT, 'diagnoza' TEXT,'przepisany lek' TEXT)  AS'  
BEGIN
 RETURN QUERY SELECT w.dzien AS dzien,p.imie, p.nazwisko, ch.nazwa, l.nazwa
 FROM pacjenci p, diagnozy d, choroby ch, wizyty w, leki l, recepty r
 WHERE p.pesel=d.pesel AND d.kod_choroby=ch.kod_choroby AND p.pesel=pe AND w.pesel=pe AND l.kod_leku=r.kod_leku AND r.nr_wizyty=w.nr_wizyty;
END;
' LANGUAGE 'plpgsql';

效果很好,但我还需要一件事。作为这个函数的结果,我得到了函数名,然后是几条记录。

但是,我想在记录上添加列名。知道怎么做吗?

要分解从函数返回的行,请像对待其他任何行一样对待它 table:

SELECT <b>* FROM</b> karta_pacjenta('foo45678901');

返回一组行的函数也称为 "table functions"。


除此之外,您提供的内容也行不通。

CREATE  FUNCTION karta_pacjenta(_pe varchar)
  RETURNS TABLE(data DATE, imie TEXT, nazwisko TEXT
              , diagnoza TEXT,przepisany lek TEXT)  AS
$func$
SELECT w.dzien, p.imie, p.nazwisko, ch.nazwa, l.nazwa
FROM   pacjenci  p
JOIN   diagnozy  d  USING (pesel) -- shorthand if columns are unambiguous
JOIN   wizyty    w  USING (pesel)
JOIN   choroby   ch ON ch.kod_choroby = d.kod_choroby
JOIN   recepty   r  ON r.nr_wizyty = w.nr_wizyty
JOIN   leki      l  ON l.kod_leku = r.kod_leku 
WHERE  p.pesel = _pe
$func$ LANGUAGE sql;
  • 列名的单引号是语法错误。必须是双引号。不过,最好始终使用不带引号的合法小写名称。

  • 不要引用语言名称,它是一个标识符。

其余的是可选的,但很好的建议。

  • 一个简单的 SQL 函数就可以完成这里的工作。

  • 使用明确的 JOIN 语法。结果相同,但更容易维护。

  • 使用 varchar(11) 而不是 varchartext 作为参数类型可能毫无意义。 (特殊情况例外。)

  • 使用美元引用 - 这在这里完全是可选的,但通常是引用函数体的好风格。迟早你会想要在正文中包含单引号。