我正在尝试为 postgresql 编写一个函数来进行一些字符串操作
该函数的目的是获取一个字符串,如果它包含括号,则删除括号中的所有内容。这就是我所得到的:
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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您需要将函数从 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.