我正在尝试为 postgresql 编写一个函数来进行一些字符串操作

发布于 2024-09-28 08:04:01 字数 501 浏览 2 评论 0原文

该函数的目的是获取一个字符串,如果它包含括号,则删除括号中的所有内容。这就是我所得到的:

CREATE FUNCTION clearmethodparams(IN qname text) RETURNS text AS
  $BODY$        
  IF position($o$($o$ in qname) = 0 THEN
    return qname;
  ELSE 
    return substring(qname from 0 for position($p$($p$ in qname)) || $c$)$c$;
  END IF;
  $BODY$
LANGUAGE sql VOLATILE;

它一直给我的错误是

错误:“IF”处或附近的语法错误 第 3 行:IF 位置($o$(qname 中的$o$) = 0 那么

我一直试图找到一些关于函数语法的好的文档,但到目前为止没有任何帮助。

The purpose of the function is to take a string and, if it contains parens, delete everything in the parens. Here's what I have:

CREATE FUNCTION clearmethodparams(IN qname text) RETURNS text AS
  $BODY$        
  IF position($o$($o$ in qname) = 0 THEN
    return qname;
  ELSE 
    return substring(qname from 0 for position($p$($p$ in qname)) || $c$)$c$;
  END IF;
  $BODY$
LANGUAGE sql VOLATILE;

The error it keeps giving me is

ERROR: syntax error at or near "IF"
LINE 3: IF position($o$($o$ in qname) = 0
THEN

I've been trying to find some good documentation on function syntax, but nothing so far has been helpful.

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

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

发布评论

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

评论(1

回忆那么伤 2024-10-05 08:04:01

您需要将函数从 SQL 函数“转换”为a PL/pgSQL 一 - 将“LANGUAGE sql”替换为“LANGUAGE plpgsql” “在您的 CREATE FUNCTION 语句中。此外,您还需要将代码“包装”在适当的

OTOH,您可能可以使用 SQL 函数实现相同的目的,例如使用 CASE 或类似的。

You need to "convert" the function from an SQL function to a PL/pgSQL one - replace "LANGUAGE sql" with "LANGUAGE plpgsql" in your CREATE FUNCTION statement. Also you will need to "wrap" your code in a proper block.

OTOH you could probably achieve the same with an SQL function, e.g. with some clever user of CASE or similar.

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