Apex 企业设计模式
FFLIB 是一个免费的框架,对 Apex 进行了扩展。它的结构实现了 Salesforce 推荐的Apex 企业设计模式。
在学习如何使用 FFLIB 框架之前,我们先来了解一下 Apex 企业设计模式的结构。
Apex 企业设计模式
Apex 企业设计模式的结构遵循了“关注点分离”的概念。
维基百科上对于“关注点分离”的定义是:
关注点分离(Separation of concerns,SOC)是对只与“特定概念、目标”(关注点)相关联的软件组成部分进行“标识、封装和操纵”的能力,即标识、封装和操纵关注点的能力。是处理复杂性的一个原则。由于关注点混杂在一起会导致复杂性大大增加,所以能够把不同的关注点分离开来,分别处理就是处理复杂性的一个原则,一种方法。
关注点分离是面向对象的程序设计的核心概念。分离关注点使得解决特定领域问题的代码从业务逻辑中独立出来,业务逻辑的代码中不再含有针对特定领域问题代码的调用(将针对特定领域问题代码抽象化成较少的程式码,例如将代码封装成function或是class),业务逻辑同特定领域问题的关系通过侧面来封装、维护,这样原本分散在整个应用程序中的变动就可以很好的管理起来。
企业设计模式的实现分为以下四个部分:
- 服务层(Service Layer)
- 模型层(Domain Layer)
- 选择逻辑层(Selector Layer)
- 工作单元(Unit of Work)
以上四个部分的详细定义可以参考 Martin Fowler 的网站。
服务层
服务层的作用是提供一组函数,将可重用的逻辑封装起来,供外部调用。
这里的“外部”包括了外部的应用程序和 Salesforce 本身的一些功能,比如 Visualforce 页面的控制器、Salesforce 的 API 服务等。
代码示例
用 Apex 建立一个服务类:
public with sharing class AccountService {
public static Account createAccount(String name) {
// 建立 Account 对象的逻辑
Account a = new Account(Name = name);
SavePoint sp = Database.setSavePoint();
try {
insert a;
} catch (Exception e) {
Database.rollback(sp);
throw e;
}
}
}
然后在其他代码中(比如 Visualforce 页面的控制器)就可以使用了:
Account a = AccountService.createAccount('HelloWorld Company');
模型层
每个模型层的类都是针对某个对象而创建。模型层的类中封装了针对相关对象的一系列逻辑,比如对象被增删修改之后需要自动执行的操作等。
和服务层不同的是,模型层中的逻辑是不会被外部调用的(但是可以被服务层调用)。
在 Apex 中,触发器类是典型的模型层的类。
选择逻辑层
选择逻辑层的作用是封装了查询相关对象的逻辑,从而将数据库操作与其他的层分离。
代码示例
用 Apex 建立一个选择逻辑类:
public with sharing class AccountSelector {
public static Account selectById(Id id) {
// 通过 Id 查询 Account 对象的逻辑
// ...
}
}
然后在其他代码中(比如服务层或外部代码)就可以使用了:
Account a = AccountSelector.selectById('XXXXXXXXXXXXXXXXXX');
工作单元
工作单元是一种设计模式,它负责保存在各个逻辑中被增删修改的数据,并负责将这些数据的变化写入数据库。
对于 Apex 的开发,使用工作单元可以实现以下几个方面:
- 记录一系列被增删修改的数据
- 记录数据之间的关系
- 在将数据的变化保存到数据库时,一次性写入,提高系统性能
- 在将数据的变化保存到数据库时,自动定义 SavePoint,在出现错误时自动回滚。这样就减轻了开发者的工作
比如在 .NET 的 Entity Framework中,ObjectContext 和 DbContext 的设计就体现了工作单元的模式。
Apex 企业设计模式的更多相关文章
- 用 FFLIB 实现 Apex 企业设计模式
Apex 企业设计模式将应用分为服务层.模型层.选择逻辑层.工作单元几个部分.FFLIB 是一个开源的 Apex 框架,可以帮助开发者快速建立相关的功能. FFLIB 的安装 FFLIB 可以直接部署 ...
- Java设计模式学习资源汇总
本文记录了Java设计模式学习书籍.教程资源.此分享会持续更新: 1. 设计模式书籍 在豆瓣上搜索了一把,发现设计模式贯穿了人类生活的方方面面.还是回到Java与程序设计来吧. 打算先归类,再浏览,从 ...
- ASP.NET 设计模式(转)
Professional ASP.NET Design Patterns 为什么学习设计模式? 运用到ASP.NET应用程序中的设计模式.原则和最佳实践.设计模式和原则支持松散耦合.高内聚的代码,而这 ...
- 【设计模式系列】之OO面向对象设计七大原则
1 概述 本章叙述面向向对象设计的七大原则,七大原则分为:单一职责原则.开闭原则.里氏替换原则.依赖倒置原则.接口隔离原则.合成/聚合复用原则.迪米特法则. 2 七大OO面向对象设计 2.1 单一 ...
- Head First设计模式分析学习
永不放弃的毅力,和对欲望的控制. 注意:要能够理解相类似的设计模式之间的区别和不同.可以把类比列举出来,加深记忆. 是否加入Spring容器中的标准是是否要用到Spring框架的方法或者功能特性,如事 ...
- asp.net资料! (.NET) (ASP.NET)
使用SqlBulkCopy类加载其他源数据到SQL表 在数据回发时,维护ASP.NET Tree控件的位置 vagerent的vs2005网站开发技巧 ASP.NET2.0小技巧--内部控件权限的实现 ...
- 身为java程序员你需要知道的网站(包含书籍,面试题,架构...)
推荐几本书<高级java程序员值得拥有的10本书>, 首页 所有文章 资讯 Web 架构 基础技术 书籍 教程 我要投稿 更多频道 » - 导航条 - 首页 所有文章 资讯 Web ...
- Java编程之路相关书籍(三个维度)
一.关于Java的技术学习.能够依照以下分三个维度进行学习 : (1)向下发展,也就是底层的方向 建议看<深入Java虚拟机>.<Java虚拟机规范>.<Thinking ...
- Systemweaver — 电子电气协同设计研发平台
当前电子电气系统随着功能安全.AutoSAR.车联网.智能驾驶等新要求,导致其复杂性.关联性日益上升.当前,传统基于文档的设计由于其低复用性.无关联性.无协同性等缺点,已经无法适应日益 ...
随机推荐
- django实现多种支付、并发订单处理
django实现多种支付方式 ''' #思路 我们希望,通过插拔的方式来实现多方式登录,比如新增一种支付方式,那么只要在项目中新增一个py文件,导入里面的pay方法就可以了,这样在支付业务中支付语句是 ...
- 剑指Offer-35.两个链表的第一个公共结点(C++/Java)
题目: 输入两个链表,找出它们的第一个公共结点. 分析: 先统计两个链表的长度,计算他们的差值,然后将两个链表对齐,再去寻找公共节点即可. 程序: C++ class Solution { publi ...
- 【2019.8.15 慈溪模拟赛 T1】插头(plugin)(二分+贪心)
二分 首先,可以发现,最后的答案显然满足可二分性,因此我们可以二分答案. 然后,我们只要贪心,就可以验证了. 贪心 不难发现,肯定会优先选择能提供更多插座的排插,且在确定充电器个数的情况下,肯定选择能 ...
- 基于Django的Rest Framework框架的视图组件
本文目录 一 基本视图 二 mixin类和generice类编写视图 三 使用generics 下ListCreateAPIView,RetrieveUpdateDestroyAPIView 四 使用 ...
- pytest框架之allure报告生成
一.关于安装 allure是跟pytest一起集成使用的,所以需要同时安装pytest以及allure-pytest插件: pip install pytest pip install allure- ...
- PHP TP框架自定义打印函数P
效果如下,有个灰色背景,也不一定是灰色可以改 代码: //传递数据以易于阅读的样式格式化后输出function p($data){ // 定义样式 $str='<pre style=" ...
- 关于C#异常的处理
关于异常,从我们一开始写代码的时候就开始伴随着我们,只不过那时还没入门,脑子里并没有产生意识这就是异常.异常:程序运行期间发生错误,异常对象: 将程序发生的各种错误封装成对象曾记得第一次面试的时候,面 ...
- 7个Python小坑,给新手党的福利
Python语言简单易用,但容易给新入门的朋友造成一些微妙的,难以捕捉的错误,稍不注意就入坑了. 因此,今天给大家总结一些易犯的小错误,让你轻松进行不踩坑的Python学习. 1.缩进,符号和空格不正 ...
- E203 CSR rtl实现分析
CSR状态控制寄存器,每个hart都有自己的CSR.对于每个hart,可以配置的状态寄存器是4k.CSR寄存器的功能见:https://www.cnblogs.com/mikewolf2002/p/1 ...
- 从高版本的 SQL Server 向低版本的 SQL Server 转移数据
1.在源数据库上右键任务,选择生成脚本- 2.在生成脚本的高级选项中,根据数据库的内容,选择相应的选项,主要是红框圈出的部分,最后选择仅架构(若数据库的数据量不大,可以直接导出 架构和数据,在新数据库 ...