我正在尝试创建一个返回一个SELECTed结果集的函数.
当我打电话给我的postgres函数像这样select * from tst_dates_func()我得到一个错误如下所示:
当我打电话给我的postgres函数像这样select * from tst_dates_func()我得到一个错误如下所示:
ERROR: query has no destination for result data HINT: If you want to discard the results of a SELECT,use PERFORM instead. CONTEXT: PL/pgSQL function "tst_dates_func" line 3 at SQL statement ********** Error ********** ERROR: query has no destination for result data SQL state: 42601 Hint: If you want to discard the results of a SELECT,use PERFORM instead. Context: PL/pgSQL function "tst_dates_func" line 3 at SQL statement
这是我创建的功能:
CREATE OR REPLACE FUNCTION tst_dates_func() RETURNS TABLE( date_value date,date_id int,date_desc varchar) as $BODY$ BEGIN select a.date_value,a.date_id,a.date_desc from dates_tbl a; END; $BODY$ LANGUAGE plpgsql;
我不知道为什么我得到上面的错误.我想从tst_dates_func()运行select *
并获取数据.或者如果需要,可以进一步加入结果集.这里有什么问题?
解决方法
做简单的sql
CREATE OR REPLACE FUNCTION tst_dates_func() RETURNS TABLE( date_value date,date_desc varchar) as $BODY$ select a.date_value,a.date_desc from dates_tbl a; $BODY$ LANGUAGE sql;
如果您真的需要使用plpgsql的返回查询
CREATE OR REPLACE FUNCTION tst_dates_func() RETURNS TABLE( date_value date,date_desc varchar) as $BODY$ BEGIN perform SELECT dblink_connect('remote_db'); return query select a.date_value,a.date_desc from dates_tbl a; END; $BODY$ LANGUAGE plpgsql;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。