llll_fighting 2022-06-07 11:30 采纳率: 100%
浏览 69
已结题

Oracle函数转成pgsql函数 有没有可以解决的

CREATE OR REPLACE FUNCTION "QUERYCARSTATUS"(
p_car_id VARCHAR2,--车辆编号
p_dev_id VARCHAR2--设备全国统一编号
)
return NUMBER
IS
n_caryy NUMBER;--
n_cargz NUMBER;
n_carjx NUMBER;
Result number;
BEGIN
--如果车辆状态不是"运营(2)"状态,视为停运状态
SELECT COUNT(1) INTO n_caryy FROM TB_dtb_CAR WHERE VEHICLE_STATE = '2' AND ID=p_car_id;
IF n_caryy = 0 THEN
Result := 4;--停运
ELSE
--如果有未处理的故障记录,视为故障状态
SELECT COUNT(1) INTO n_cargz FROM TB_JX_CLGZJL WHERE CLZT = '0' AND CAR_ID=p_car_id;
IF n_cargz > 0 THEN
Result := 3;--故障
ELSE
--如果没有学员登签未登出记录,视为空闲状态,否则视为教学状态
SELECT COUNT(1) INTO n_carjx FROM TB_JP_STUDENT_LOGIN WHERE LOGOUT_TIME IS NULL AND device_num=p_dev_id;
IF n_carjx = 0 THEN
Result := 2;--空闲
ELSE
Result := 1;--教学
END IF;
END IF;
END IF;
return(Result);
END;

  • 写回答

1条回答 默认 最新

  • leaf_cq 2022-06-09 15:22
    关注

    1、你可以一个SQL实现,也可以将下面SQL放到你函数中,替换函数主体内容即可:

        SELECT CASE WHEN NOT EXISTS( SELECT 1 FROM TB_dtb_CAR WHERE VEHICLE_STATE = '2' AND ID = p_car_id ) < 1 THEN 4 -- 停运
                    WHEN EXISTS( SELECT 1 FROM TB_JX_CLGZJL WHERE CLZT = '0' AND CAR_ID = p_car_id ) THEN 3 -- 故障
                    WHEN NOT EXISTS( SELECT 1 FROM TB_JP_STUDENT_LOGIN WHERE LOGOUT_TIME IS NULL AND device_num = p_dev_id ) THEN 2 -- 空闲
                    ELSE 1 END INTO Result ; --教学
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

    报告相同问题?

    问题事件

    • 系统已结题 7月2日
    • 已采纳回答 6月24日
    • 创建了问题 6月7日

    悬赏问题

    • ¥15 (关键词-聊天软件)
    • ¥15 求大家看看这个编程的编法没有思路啊
    • ¥20 WSL打开图形化程序子窗口无法点击
    • ¥15 Jupyter Notebook 数学公式不渲染
    • ¥20 ERR_CACHE_MISS 确认重新提交表单
    • ¥20 关于vba使用HTMLfile执行js函数问题
    • ¥60 悬赏求解,通过实时现场摄像头的视频图像识别其他对家打出的麻将牌,识别麻将牌,识别牌墙位置,通过识别对家打出了什么牌
    • ¥15 关于#GPU jetson#的pcie驱动开发问题,如何解决?
    • ¥15 stm32f103zet6 串口5无法收发数据
    • ¥15 关于C语言使用线程队列实现多线程并发