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;
Oracle函数转成pgsql函数 有没有可以解决的
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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 ; --教学
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
- ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
- ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
- ¥20 腾讯企业邮箱邮件可以恢复么
- ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
- ¥15 错误 LNK2001 无法解析的外部符号
- ¥50 安装pyaudiokits失败
- ¥15 计组这些题应该咋做呀
- ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
- ¥15 让node服务器有自动加载文件的功能