APEX开发过程中需要注意的小细节4

2024-03-23 04:12

本文主要是介绍APEX开发过程中需要注意的小细节4,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

去除右上角保存提示

每次编辑/更新如果未保存离开当前页面会有弹窗警告并且需要点击才能执行下一步,感觉很不方便

对应的页-导航-关闭“有未保存更改时发出警告”

保证只有一周内创建的数据可以被修改

原来条件项:

SELECT * FROM JAS_PROJECT_DETAIL WHERE create_date + INTERVAL '3' DAY > CURRENT_TIMESTAMP ;
弊端:会在每个create_date创建时间执行一次+3天的操作,有多少条数据就执行多少次,对执行效率不友好

新代码:

SELECT count(1)
FROM JAS_PROJECT_DETAIL
WHERE create_date > sysdate - 7and "project_detail_id" = :P203_project_detail_id;
优点:只需在当前时间做一次-7天的操作即可,将操作结果和创建时间作比较即可,执行效率比之前大大提高

提示暂无编辑权限/创建已超过7天

条件项P203_IS_DATE

源- 类型 “SQL查询(返回单个值)”- SQL查询 - 已使用 “始终替换会话中的任何值”

SELECT count(1)
    FROM JAS_PROJECT_DETAIL
    WHERE create_date > sysdate - 7
      and "project_detail_id" = :P203_project_detail_id;

条件项P203_IS_EDIT

源- 类型 “SQL查询(返回单个值)”- SQL查询 - 已使用 “始终替换会话中的任何值”

select distinct count(1)  from DIGITAL_USER_GROUP_DETAILS
where upper(USER_ID)  = upper(:U_ID)
and USER_GROUP_ID in (300018,300120,500000);

不可编辑页面

点击更新id,弹出编辑弹窗,若是没有编辑权限/超过七天会有提示,并且隐藏更新按钮

可编辑页面

点击更新id,弹出编辑弹窗,若是有编辑权限/未过七天,会开放更新按钮隐藏提示

css提示样式设置: 对应的页-CSS-内嵌

/* 定义警告框的基本样式 */
.alert-box {padding: 15px;margin-bottom: 20px;border: 1px solid transparent;border-radius: 4px;
}/* 定义不同类型警告框的样式 */
.alert-box.success {color: #3c763d;background-color: #dff0d8;border-color: #d6e9c6;
}.alert-box.info {color: #31708f;background-color: #d9edf7;border-color: #bce8f1;
}.alert-box.warning {color: #8a6d3b;background-color: #fcf8e3;border-color: #faebcc;
}.alert-box.danger {color: #a94442;background-color: #f2dede;border-color: #ebccd1;
}

提示项-项-高级 前置文本

<div class="alert-box danger">创建已超过一周/您暂无权限编辑,仅可查看</div>

可编辑日期不要七天内,而是仅限本周

之前

SELECT count(1)
    FROM JAS_PROJECT_DETAIL
    WHERE create_date > sysdate - 7
      and "project_detail_id" = :P203_project_detail_id;

现在

SELECT count(1)
    FROM JAS_PROJECT_DETAIL
    WHERE TO_CHAR(CREATE_DATE, 'YYYYIW') = TO_CHAR(TRUNC(SYSDATE), 'YYYYIW')
      and "project_detail_id" = :P203_project_detail_id;

要检查Oracle SQL中的创建时间是否在本周内,可以使用TO_CHAR函数结合TRUNC函数来比较日期。以下是一个示例SQL查询,它检查字段creation_date是否在本周内

这里的IW格式模型代表ISO标准下的周数,它是从周一开始,包含周日的周数。TRUNC(SYSDATE)会将当前日期时间截断到星期一(如果今天是星期一,则为当前星期;如果是其他星期,则为上一个星期一)。TO_CHAR(creation_date, 'YYYYIW')将创建时间转换为年和周数,与当前年和周数进行比较,以确定是否在本周内。

【问题记录】

  • 处理 "自定义-项目内容编辑" 分配了无效(非多行)可编辑区域。

【交互式网格中设置仅展示/只读模式】

 我只想让本周工作计划回显即可,输入类型为富文本/多文本编辑,如果展示设为“仅展示”,就会得到下图效果↓

如何解决呢?

展示依旧是“多文本编辑”类型,但是设置 只读 - 类型 始终 -执行 每一行

【varchar2和number的类型转换】

在开发过程中经常会遇到因输入的类型与项的原类型不一致导致的类型错误,最常见的就是

varchar2和number的类型转换

update JAS_PROJECT_MASTERset "current_progress" = to_number(replace(:P203_PROGRESS,'%',''))where "project_id" = :P203_PROJECT_ID;v_row_count1 := sql%rowcount + v_row_count  ;--后续根据“计划开始时间”和“计划完成时间”自动计算“项目进度”,不用手动录入

原来的:P203_PROGRESS是number类型,但是显示时拼接了%,为了避免%对其类型的影响,采用to_number及replace函数。

【有数据则展示,无数据则不展示,避免字段展示出来但是没有数据的情况】

服务器端条件 -类型 “已返回行”

select 1 from "JAS_PROJECT_MASTER"
where "plan_to_end_date" is not null
and "project_id" = :P201_PROJECT_ID

【问题记录】处理 " 保存编辑后的表单数据" 分配了无效(非多行)可编辑区域

begincase :APEX$ROW_STATUSwhen 'U' thenupdate JAS_PROJECT_MASTERset"project_name"       = :PROJECT_NAME,"project_class"      = :PROJECT_CLASS,"important_grade"    = :IMPORTANT_GRADE,"project_status"= :PROJECT_STATUS,"project_scope"= :PROJECT_SCOPE,"leading_unit"= :LEADING_UNIT,
--                           "current_progress"= to_number(replace(:progress,'%','')), --自动结算,手输舍弃"project_owner"= :PROJECT_OWNER,"project_target"= :PROJECT_TARGET,"project_content" = :PROJECT_CONTENT,"progress_memo"= :PROGRESS_MEMO, --进度说明"project_memo" = :PROJECT_MEMO, --备注"start_date"= :START_DATE,"plan_to_end_date" = :plan_to_end_date,"actual_end_date"= :ACTUAL_END_DATE,REQUEST_CONTACT_POINT= :REQUEST_CONTACT_POINT,HQIT_TEAM= :HQIT_TEAM,HQIT_TEAM_CP= :HQIT_TEAM_CP,VENDOR= :VENDOR,VENDOR_CP= :VENDOR_CP,"attached_format" = :ATTACHED_FORMAT ,  --附件格式"attached_progress_plan" = :ATTACHED_PROGRESS_PLAN,  --附件上传"project_link" = :PROJECT_LINK,   -- 项目链接UPDATOR = :USER_ACCOUNT, --项目表更新人UPDATE_DATE = sysdate  --项目表更新时间where "project_id" = :P202_PROJECT_ID;end case;
end;

【数据展示出不来】看板展示某月数据出不来,查看日志显示

output value too large (maximum: 4000) 输出值太大(最大值:4000)

【解决方法】将字符串转化为json,加上returning clob

【开发技巧】根据用户设置编辑权限

想要管控的项-只读-函数体

DECLARE
L_AUTH NUMBER(2);
BEGIN
select distinct count(1) into L_AUTH  from DIGITAL_USER_GROUP_DETAILS
where upper(USER_ID) = upper(:U_ID)
and USER_GROUP_ID not in (500000,300018);
RETURN L_AUTH>=1;
END;

这篇关于APEX开发过程中需要注意的小细节4的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/837105

相关文章

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

C++链表的虚拟头节点实现细节及注意事项

《C++链表的虚拟头节点实现细节及注意事项》虚拟头节点是链表操作中极为实用的设计技巧,它通过在链表真实头部前添加一个特殊节点,有效简化边界条件处理,:本文主要介绍C++链表的虚拟头节点实现细节及注... 目录C++链表虚拟头节点(Dummy Head)一、虚拟头节点的本质与核心作用1. 定义2. 核心价值二

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF