【Oracle APEX开发小技巧12】

有如下需求:

有一个问题反馈页面,要实现在apex页面展示能直观看到反馈时间超过7天未处理的数据,方便管理员及时处理反馈。

我的方法:直接将逻辑写在SQL中,这样可以直接在页面展示

完整代码:

sql 复制代码
SELECT
    SF.FEEDBACK_ID,
    SF.FEEDBACK_CONTENT,
    SF.FILE_ID,
    FO.FILE_NAME || '(ID:' || SF.FILE_ID || ')' ||
    CASE
        WHEN FO.DEL_FLAG = 1 THEN '(文件已删除)'
        ELSE ''
    END AS FOLDER_DISPLAY,
    SF.USER_ID,--反馈人(原存储MPF_USER_ID,后被告知只能获取钉钉ID,已弃用)
    SF.DING_USER_ID,--反馈人(获取钉钉ID)--BY:wxx 2025-04-29
    SF.STATUS,
    SF.FEEDBACK_TYPE,
    -- 根据反馈时间和状态判断是否标红
    CASE
        WHEN SF.FEEDBACK_DATE < SYSDATE - 7 AND SF.STATUS = 0 THEN
            '<span style="color:red;">' || TO_CHAR(SF.FEEDBACK_DATE, 'YYYY-MM-DD HH24:MI:SS') || '</span>'
        ELSE
            TO_CHAR(SF.FEEDBACK_DATE, 'YYYY-MM-DD HH24:MI:SS')
    END AS FEEDBACK_DATE,
    NVL(TO_CHAR(SF.PROCESS_DATE, 'YYYY-MM-DD HH24:MI:SS'), '-') AS PROCESS_DATE,
    NVL(TO_CHAR(SF.PROCESS_USER_ID), '-') AS PROCESS_USER_ID,
    -- 根据处理日期显示操作提示
    CASE
        WHEN SF.PROCESS_DATE IS NULL THEN '处理'
        ELSE '查看处理意见'
    END AS OPERATION
FROM
    STS_FEEDBACK SF
    LEFT JOIN STS_FILE FO ON SF.FILE_ID = FO.FILE_ID
    LEFT JOIN BASIC_USER  DU ON DU.USER_ID = SF.DING_USER_ID
WHERE
    SF.DEL_FLAG = 0
    AND SF.TENANT_ID = :USER_TENANT
    -- 文件可以删除,但是反馈保留
    AND FO.TENANT_ID = :USER_TENANT
    AND (SF.STATUS = TO_NUMBER(NVL(:P201_STATUS, 99)) OR TO_NUMBER(NVL(:P201_STATUS, 99)) = 99);

关键逻辑

sql 复制代码
CASE
    WHEN SF.FEEDBACK_DATE < SYSDATE - 7 AND SF.STATUS = 0 THEN
        '<span style="color:red;">' || TO_CHAR(SF.FEEDBACK_DATE, 'YYYY-MM-DD HH24:MI:SS') || '</span>'
    ELSE
        TO_CHAR(SF.FEEDBACK_DATE, 'YYYY-MM-DD HH24:MI:SS')
END AS FEEDBACK_DATE

光有sql还不行,要在对应的列FEEDBACK_DATE设置对应格式,FEEDBACK_DATE→列→类型【HTML表达式】→设置 HTML表达式【<span >&FEEDBACK_DATE.</span>】

关键逻辑:

  1. 当反馈时间超过7天(SYSDATE - 7)且状态为0(未处理)时,反馈时间会显示为红色
  2. 其他情况下正常显示

相关字段关联

  1. 处理时间:PROCESS_DATE字段显示处理时间,未处理时显示'-'

  2. 处理人:PROCESS_USER_ID字段显示处理人ID,未处理时显示'-'

  3. 操作提示:根据PROCESS_DATE是否为空显示"处理"或"查看处理意见"

效果展示:

相关推荐
web安全工具库2 小时前
Linux进程的:深入理解子进程回收与僵尸进程
java·linux·数据库
麦聪聊数据2 小时前
大数据与云原生数据库中的 SQL2API:优化跨平台数据访问与查询
数据库·sql·云原生
虚伪的空想家2 小时前
记录次etcd故障,fatal error: bus error
服务器·数据库·k8s·etcd
笨手笨脚の3 小时前
Mysql 的锁机制
数据库·mysql··死锁·间隙锁
老友@3 小时前
一次由 PageHelper 分页污染引发的 Bug 排查实录
java·数据库·bug·mybatis·pagehelper·分页污染
hzk的学习笔记3 小时前
Redisson解锁失败,watchdog会不会一直续期下去?
数据库·redis·缓存
合作小小程序员小小店3 小时前
web网页开发,在线%商城,电商,商品购买%系统demo,基于vscode,apache,html,css,jquery,php,mysql数据库
开发语言·前端·数据库·mysql·html·php·电商
TDengine (老段)3 小时前
TDengine 字符串函数 CONCAT 用户手册
java·数据库·tdengine
一 乐4 小时前
旅游|内蒙古景点旅游|基于Springboot+Vue的内蒙古景点旅游管理系统设计与实现(源码+数据库+文档)
开发语言·前端·数据库·vue.js·spring boot·后端·旅游
bing.shao4 小时前
如何降低redis哈希值冲突概率
数据库·redis·哈希算法