如何从函数返回的表中获取单个列?

时间:2015-01-25 15:00:41

标签: database postgresql function rows plpgsql

我试图用返回表创建一个函数。

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';

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

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

1 个答案:

答案 0 :(得分:1)

要分解从函数返回的行,请将其视为任何其他表:

SELECT * FROM karta_pacjenta('foo45678901');

返回一组行的函数也称为“表函数”。


除此之外,你提出的内容不起作用。

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作为参数类型可能毫无意义。 (适用拐角案例例外。)

  • 使用美元引用 - 这里完全是可选的,但通常引用函数体的好样式。迟早你会想要在身体中加入单引号。