首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >函数中If语句的PGSQL错误

函数中If语句的PGSQL错误
EN

Stack Overflow用户
提问于 2014-08-06 18:53:20
回答 1查看 100关注 0票数 0

我正在尝试为pgsql创建一个函数,如果报告厅中存在设备,我需要返回一个布尔值。我得到以下错误:

"ERROR: return type mismatch in function declared to return boolean"

"DETAIL: Function's final statement must be SELECT or INSERT/UPDATE/DELETE RETURNING."

代码语言:javascript
复制
CREATE FUNCTION hasProjector(int) RETURNS boolean AS $$
        DO
        $do$
        BEGIN
        IF EXISTS(SELECT * FROM LectureRoomEquipment WHERE LectureRoomID = $1 AND             EquipmentID = 1) THEN
            SELECT true AS hasProjector;
        ELSE
            SELECT false AS hasProjector;
        END IF;
        END
        $do$
    $$ LANGUAGE SQL;

有没有人建议我哪里做错了,以及我如何解决这个问题?谢谢。

EN

回答 1

Stack Overflow用户

发布于 2014-08-06 20:53:46

您不需要plpgsql。使用纯SQL执行此操作

代码语言:javascript
复制
create function hasprojector(int) returns boolean as $$

    select exists (
        select *
        from lectureroomequipment
        where lectureroomid = $1 and equipmentid = 1
    );

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

https://stackoverflow.com/questions/25158516

复制
相关文章

相似问题

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