postgresql中的返回表

发布于 2025-02-11 14:50:34 字数 213 浏览 0 评论 0原文

我将存储过程从SQL Server迁移到PostgreSQL。我应该退回表。但是,我有以下问题:

IF ROWSTATE = 'L' THEN
      return TABLE A;
ELSIF ROWSTATE = 'C' THEN
      return TABLE B;
END IF

如何执行此操作,在PostgreSQL中使用函数?

I am migrating stored procedure from SQL SERVER to POSTGRESQL. I should return table. But, I have following problem:

IF ROWSTATE = 'L' THEN
      return TABLE A;
ELSIF ROWSTATE = 'C' THEN
      return TABLE B;
END IF

How to do it, using function in POSTGRESQL?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

梦幻的味道 2025-02-18 14:50:34

您必须创建一个返回表的函数,并在表中预期的列ab,例如:

CREATE OR REPLACE FUNCTION myfunc(rowstate text)
RETURNS TABLE (ret_col1 text, ret_col2 text) AS $ 
BEGIN
  IF $1='L' THEN
    RETURN QUERY SELECT cola1, cola2 FROM a;
  ELSEIF $1='C' THEN
    RETURN QUERY SELECT colb1, colb2 FROM b;
  END IF;
END;
$ LANGUAGE plpgsql;

demo: db<>>>>>&code

You have to create a function that RETURNS TABLE with the columns expected from tables a and b, e.g:

CREATE OR REPLACE FUNCTION myfunc(rowstate text)
RETURNS TABLE (ret_col1 text, ret_col2 text) AS $ 
BEGIN
  IF $1='L' THEN
    RETURN QUERY SELECT cola1, cola2 FROM a;
  ELSEIF $1='C' THEN
    RETURN QUERY SELECT colb1, colb2 FROM b;
  END IF;
END;
$ LANGUAGE plpgsql;

Demo: db<>fiddle

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文