没有源代码的Ex扩展开发
经常会在没有源代码的情况下修改标准产品的业务逻辑,又担心到时打补丁时造成元数据元代码的冲突。为此总部推出的Ex开发。这种开发的原理是 在调用java代码的时候 会先检测是否存在后缀为Ex的相同单据名称代码,如 FeeLimitEditUI (标准产品的jar包class文件)如果你自己写了一个类叫FeeLimitEditUIPIEx而且是继承FeeLimitEditUI 那么就会优先调用FeeLimitEditUIPIEx这个类里面的实现逻辑。从而达到对标准产品业务逻辑的改造工作,而不用担心后续打补丁的冲突。
当然,也分客户端和服务器端方法。客户端方法 主要是UI 只需要自己建一个与原单据java文件同名+PIEx 继承自原单据的java文件,然后改写里面的实现逻辑。比如在某列表界面 标准产品里对 actionEdit_actionform 里面做了逻辑判断 单据状态为启用的单据 则不能编辑,现在需要不加这个逻辑。那你直接super 就改不了。只有自己实现edit方法了。这个就相对比较复杂。服务器端方法 直接新增一个java类+Ex 来继承某ControllerBean这样就行不通了,刚开始做的时候我也是这么做 ,结果就是并没有调用这个类里面的方法。
后面找了下资料,服务器端要实现Ex开发 必须在业务单元的功能里面添加一个功能 然后发布,这样XXControllerBeanEx.java会自动生成,你添加的功能对应的方法也在里面,然后你只需要修改里面的实现逻辑即可。
当然,在没有源代码的情况下 还有种方式是反编译class文件 然后修改实现逻辑 来覆盖服务器端的class。这种方法 可能造成以后补丁打了不起作用,就需要手动合并源代码。
名词解释
SCM:SCM(Supply Chain Management)
CRM:CRM(Customer Relationship Management)就是客户关系管理
OA是Office Automation的简写
HR-Human Resource人力资源
BI:商业智能(BI,Business Intelligence)。商业智能的概念最早在1996年提出。当时将商业智能定义为一类由数据仓库(或数据集市)、查询报表、数据分析、数据挖掘、数据备份和恢复等部分组成的、以帮助企业决策为目的技术及其应用。目前,商业智能通常被理解为将企业中现有的数据转化为知识,帮助企业做出明智的业务经营决策的工具。商务智能系统中的数据来自企业其他业务系统。例如商贸型企业,其商务智能系统数据包括业务系统的订单、库存、交易账目、客户和供应商信息等,以及企业所处行业和竞争对手的数据、其他外部环境数据。而这些数据可能来自企业的CRM、SCM等业务系统。 商业智能能够辅助的业务经营决策,既可以是操作层的,也可以是战术层和战略层的决策。为了将数据转化为知识,需要利用数据仓库、联机分析处理(OLAP)工具和数据挖掘等技术。因此,从技术层面上讲,商业智能不是什么新技术,它只是数据仓库、OLAP和数据挖掘等技术的综合运用。
ETL,Extraction-Transformation-Loading的缩写,中文名称为数据提取、转换和加载。 ETL工具有:OWB(Oracle Warehouse Builder)、ODI(Oracle Data Integrator)、Informatic PowerCenter、AICloudETL、DataStage、Repository Explorer、Beeload、Kettle、DataSpider
OLTP&OLAP:当今的数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing)、联机分析处理OLAP(On-Line Analytical Processing)。OLTP是传统的关系型数据库的主要应用,主要是基本的、日常的事务处理,例如银行交易。OLAP是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。下表列出了OLTP与OLAP之间的比较。
OLTP | OLAP | |
用户 | 操作人员,低层管理人员 | 决策人员,高级管理人员 |
功能 | 日常操作处理 | 分析决策 |
DB 设计 | 面向应用 | 面向主题 |
数据 | 当前的, 最新的细节的, 二维的分立的 | 历史的, 聚集的, 多维的 集成的, 统一的 |
存取 | 读/写数十条记录 | 读上百万条记录 |
工作单位 | 简单的事务 | 复杂的查询 |
DB 大小 | 100MB-GB | 100GB-TB |