首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >PostgreSQL中"IF“处或附近的语法错误

PostgreSQL中"IF“处或附近的语法错误
EN

Stack Overflow用户
提问于 2022-01-07 16:05:06
回答 1查看 133关注 0票数 0

我试图在PostgreSQL上编写一个sql函数,但是在‘IF’上有一个错误:

代码语言:javascript
代码运行次数:0
运行
复制
ERROR: Syntax error at or near "IF"
LINE 11: IF Type = 's' THEN

我不明白语法错误。

(没有IF正确工作的函数)

我的SQL代码:

代码语言:javascript
代码运行次数:0
运行
复制
CREATE OR REPLACE FUNCTION public.add_activity(IDactivity smallint,Date_Start date, Data_End date, 
Type character varying,Name character varying DEFAULT NULL::character varying,
Typology character varying DEFAULT NULL::character varying, Client smallint DEFAULT NULL::smallint)
RETURNS void
LANGUAGE 'sql'
AS $BODY$

INSERT INTO public."Activity" 
VALUES(IDactivity, Date_Start, Data_End, Type, Name);

IF Type = 's' THEN
INSERT INTO public."Service" 
VALUES(IDactivity, Typology, Client); 

END IF;
$BODY$;

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-01-07 16:23:20

IF不是用sql语言实现的,而是用plpgsql语言实现的,参见手册

您可以将LANGUAGE sql替换为LANGUAGE plpgsql,然后在函数体中添加BEGINEND

代码语言:javascript
代码运行次数:0
运行
复制
CREATE OR REPLACE FUNCTION public.add_activity(IDactivity smallint,Date_Start date, Data_End date, 
Type character varying,Name character varying DEFAULT NULL::character varying,
Typology character varying DEFAULT NULL::character varying, Client smallint DEFAULT NULL::smallint)
RETURNS void
LANGUAGE plpgsql
AS $BODY$
BEGIN
INSERT INTO public."Activity" 
VALUES(IDactivity, Date_Start, Data_End, Type, Name);

IF Type = 's' THEN
INSERT INTO public."Service" 
VALUES(IDactivity, Typology, Client); 
END IF;

END ;
$BODY$

或者您可以更改代码以保留sql语言:

代码语言:javascript
代码运行次数:0
运行
复制
CREATE OR REPLACE FUNCTION public.add_activity(IDactivity smallint,Date_Start date, Data_End date, 
Type character varying,Name character varying DEFAULT NULL::character varying,
Typology character varying DEFAULT NULL::character varying, Client smallint DEFAULT NULL::smallint)
RETURNS void
LANGUAGE sql
AS $BODY$

INSERT INTO public."Activity" 
VALUES(IDactivity, Date_Start, Data_End, Type, Name);

INSERT INTO public."Service"
SELECT IDactivity, Typology, Client
WHERE Type = 's' ;

$BODY$
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70624031

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档