一  什么是BO

BO(Business Object),封装在数据库之上,用于直接操作数据(增、删、改、查)

针对不同的BO,在安装目录下有对应的DLL文件,其中封装了BO各式针对具体的业务的方法,可以直接调用BO方法进行二次开发,可以使用反编译软件查看这些源代码。

Erp.Contracts.BO.XXX.dll

Adapter是封装在BO之上的一个类,其中囊括了BO的方法,也有特有的一部分功能。

Erp.Adapters.XXX.dll

UI层可以分为两个部分,Forms窗体控件以及看不见的逻辑数据处理Transaction。
Erp.UI.XXXEntry.dll

二  特点与优势

完善的BO体系,所有的业务处理都有对应的BO。
数据的完整性,对于数据的校验以及控制十分完善。
数据的安全性。

Adapter能做什么?

同样能操作数据,但是较之BO使用更加简便。
用于搜索对话框(Adapter对应的InvokeSearch方法)
更多的事件选择(BeforeAdapterMethod事件,AfterAdapterMethod事件)

Transaction是介于UI层与Adapter之间,用于将Adapter的数据与控件进行关联以及实现UI层的特定动作。
通常一个窗体只有一个Transaction对象,即oTrans,而一个Transaction对象,可以包含多个Adapter。

直接调用UI层特定接口的方法,如每个UI层对应不同的保存方法:oTrans.Update()

说到与控件的关联非Epibinding属性莫属,使用Notify 方法实时发布数据到控件。

每个Transaction实例中包含EpiDataViews属性,包括了Forms使用到的所有EpiDataView。

三 EpiDataView应用

1 获取、修改UI层特定字段的数据
2 绑定控件的灵活性
3 更多的事件选择
4 各式向导(图像列向导、规则向导、修改扩展属性)

四 获取数据的方法

先了解一下ListDataSet 与 RowsDataSet

Epicor所有获取数据的方法都是使用BO,以下只是形式不同,本质是一样的。

1 SearchFunctions.listLookUp

优点:简单粗暴,可以选择弹出或者不弹出搜索对话框
缺点:只能获取ListDataSet的数据。
DataSet ds = SearchFunctions.listLookup(oTrans, adapterName, out recSelected, bShowDialog, whereClause);

Ice.UI.EpiUIFunctionLib.dll

2 SearchFunctions.showLookUp

优点:可以获取ListDataSet或者RowsDataSet
缺点:必须弹出搜索对话框。
  DataSet ds= SearchFunctions.showLookup(oTrans, "JobEntryAdapter", out recSelected,  bMutilSelect  ,  bUseList ,whereClause);

利用Adapter的InvokeSearch方法。配合SearchOption使用。

优点:获取数据方式灵活,根据SearchOption不同而不同,可以修改数据。
缺点:需要定义适配器。
[范例]
string whereClause = "Key1 = '" + Key1 + "' And Key2 = '" + Key2 + "'";     System.Collections.Hashtable wcHash = new System.Collections.Hashtable(1);    wcHash.Add("UD05", whereClause);    SearchOptions opts = SearchOptions.CreateRuntimeSearch(wcHash, DataSetMode.RowsDataSet);
_ud05Adapter.InvokeSearch(opts);
    //这样获取的数据在adapter中
    //DataTable dt=_ud05Adapter.UD05Data.UD05;
    if(_ud05Adapter.UD05Data.UD05.Rows.Count > 0)
    {
        //TODO:
    }

利用ProcessCaller.LaunchSearch方法

优点:可以使用SearchOption,传入参数为空时,默认与listLookUp作用相同。
缺点:速度偏慢。

//第三个参数为SearchOption对象,为空时效果与listlookup相同。
DataSet ds=(DataSet)ProcessCaller.LaunchSearch(oTrans,"JobEntryAdapter","");

Adapter的GetRows,GetList方法 

GetRows:获取RowsDataSet数据
GetList:获取ListDataSet数据
注:获取的数据与InvokeSearch不同,不在Adapter中,而是通过方法返回

利用Adapter的GetByID方法

优点:简单实用
缺点:不灵活,参数多数唯一或者只是主键,需要定义适配器
注:获取的数据填入Adapter中

Business Object 开发的更多相关文章

  1. SAP中的BOPF(Business Object Processing Framework)

    希望简化你的业务应用开发过程?业务对象处理框架(Business Object Processing Framework,以下简称BOPF)也许可以帮到你. BOPF是SAP Business Sui ...

  2. ABAP术语-Business Object Type

    Business Object Type 原文:http://www.cnblogs.com/qiangsheng/archive/2008/01/10/1033480.html Generic de ...

  3. ABAP术语-Business Object Builder

    Business Object Builder 原文:http://www.cnblogs.com/qiangsheng/archive/2008/01/09/1031357.html Tool fo ...

  4. ABAP术语-Business Object

    Business Object 原文:http://www.cnblogs.com/qiangsheng/archive/2008/01/07/1028364.html Represents a ce ...

  5. ABAP术语-BOR (Business Object Repository )

    BOR (Business Object Repository ) 原文:http://www.cnblogs.com/qiangsheng/archive/2007/12/25/1013523.ht ...

  6. Format a Business Object Caption 设置业务对象标题的格式

    In this lesson, you will learn how to format the caption of a detail form that displays a business o ...

  7. Business Component(BC)和Business Object(BO)

    Siebel应用架构的一个成功的地方就是在应用里引入了BC,BO的概念,从而使得几千张关系数据表能够按照业务的含义组织成业务对象,对于业务人员而言具有了业务上的含义,而不仅仅是从技术人员的观点来对待数 ...

  8. Arc Object开发,概述2

    简介 Esri公司推出的ArcGIS产品是一个非常强大的体系,里面包含ArcGIS Desktop.ArcGIS Server.ArcGIS Engine.ArcSDE.ArcGIS Online等, ...

  9. SAP CRM 7.0中的BOL(Business Object Layer)

    业务对象层(BOL)和通用交互层(GenIL)属于业务层. 业务对象层:   在CRM WebClient会话运行期间,业务对象层存储业务对象的数据以及它们属性和关系的定义. 通用交互层 通用交互层将 ...

  10. 信息设计工具IDT创建从SAP Business Object到SAP HANA的连接

    1. 打开Information Design Tool, 并添加BO Server的连接 2. 在Connection上右击, 选择Insert Relational Connection 3. 输 ...

随机推荐

  1. SpringMVC —— RESTful案例

    案例:基于RESTful页面数据交互            

  2. PasteForm最佳CRUD实践,实际案例PasteTemplate详解(一)

    本文将介绍soft.pastecode.cn出品的PasteForm,PasteForm是贴代码使用Dto思想实现的CRUD的一个组件,或者说输出一个思想! 为啥我觉得是最佳的CRUD呢?先结合你的实 ...

  3. Serilog文档翻译系列(五) - 编写日志事件

    日志事件通过 Log 静态类或 ILogger 接口上的方法写入接收器.下面的示例将使用 Log 以便语法简洁,但下面显示的方法同样可用于接口. Log.Warning("Disk quot ...

  4. 为什么用 AWS CLI?因为我懒得点鼠标!

    在这篇博客中,我们一起深入探索 AWS CLI 的世界,从零开始,逐步构建在云端的家园.将介绍 AWS CLI 的基本功能和使用场景,如何创建 IAM 用户.VPC.子网.安全组.EC2 实例等,甚至 ...

  5. android 性能优化 -systrace

    简介: Systrace允许监视和跟踪Android系统的行为(trace).它会指明系统都在哪些工作上花费时间.CPU周期都用在哪里,甚至可以看到每个线程.进程在指定时间内都在干嘛.它同时还会突出观 ...

  6. 5.7 函数y=Asin(ωx+φ)的图像和性质

    \({\color{Red}{欢迎到学科网下载资料学习 }}\) [ [高分突破系列]高一数学上学期同步知识点剖析精品讲义与分层练习] (https://www.zxxk.com/docpack/27 ...

  7. .NET周刊【10月第1期 2024-10-06】

    国内文章 基于DPAPI+RDP技术实现本地打开远程程序,并映射到本地机器桌面上 https://www.cnblogs.com/weskynet/p/18445584 该教程讲述如何使用Remote ...

  8. k8s-NFS系统配置

    k8s-NFS系统配置 NFS(network filesystem),nfs文件系统在k8s中主要用于持久化存储,可以被多个pod访问和共享数据. 特点 数据持久性 nfs为k8s的pod提供了一种 ...

  9. 云原生爱好者周刊:使用 GitOps 来动态管理 Grafana 的数据源

    文章推荐 使用 GitOps 来动态管理 Grafana 的数据源 通过 Grafana 的 Provisioning 特性,可以在 provisioning/datasources 目录下添加多个 ...

  10. 云原生爱好者周刊:炫酷的 Grafana 监控面板集合

    开源项目推荐 grafana-dashboards-kubernetes 这个项目提供了一系列比较炫酷的用于监控 Kubernetes 的 Grafana 监控面板,灵感来源于 kubernetes- ...