测试
全部博文(931)
分类: 架构设计与优化
2019-04-10 13:53:45
SAP CRM的前世今生
在我之前的微信公众号文章 SAP的这三款CRM解决方案,您能区分清楚么我曾经提到过我作为成都SAP研究院CRM产品开发团队的一员工作过一段时间。
我向在SAP德国总部工作的德国老前辈们请教SAP CRM最早的版本是何时问世的,得到的答复是上世纪末本世纪初。
作为一个PC游戏迷,我联想到了供我领略众多国内外游戏大作的微软操作系统DOS, Windows 95, 98, 2000, Me和XP, 20年转瞬即逝,如今它们已经远离我们的视线了。
再回到我曾经工作的SAP CRM。每当Jerry在SAPGUI里调试着SAP CRM那些Created字段显示为本世纪初的ABAP代码时,脑子里情不自禁地浮现出曹老板和他神作里的千里马形象:
同样, SAP的这三款CRM解决方案,您能区分清楚么 里也提到了另一款SAP成都研究院的开发团队参与开发的产品:S/4HANA for Customer Management 1.0
今天(2018年2月28日),这款产品终于揭开了TA的神秘面纱 : 在SAP成都研究院开发团队和SAP全球其他部门同事们的共同努力下,S/4HANA for Customer Management 1.0问世了!
SAP CRM On-Premises(下文简称为SAP CRM)的部分销售和服务功能已经成功集成到了S/4HANA里, 成为了S/4HANA的一部分。对于SAP的旗舰级产品S/4HANA来说,可以用"如虎添翼"四个字来形容这一融合。作者本人也是这个产品开发团队的一份子,贡献了部分代码和一些技术难题的攻关和原型开发,为此我感到自豪。
在传统的SAP系统集成部署架构下,SAP ERP和SAP CRM通过中间件进行数据同步,其间若是配置不当,数据同步可能会出现形形色色的问题。好在SAP CRM中间件在全球有着众多用户,这个产品本身又非常成熟,因此SAP生态圈内有着众多中间件相关文档,让您在遇到问题时不会一筹莫展。
一个好消息是,在S/4HANA for Customer Management里,原本CRM和ERP数据同步过程中种种令人头痛的问题已经从设计层面上得以避免了,因为在这款产品里运行的CRM销售和服务业务,使用和生成的业务数据当然是直接存储在S/4HANA系统里的,根本就不再需要使用中间件进行数据同步了。
关于S/4HANA for Customer Management 1.0 支持的销售和服务功能细节,请参阅SAP官方帮助文档。
先看看这个产品颜值如何。点击Fiori Launchpad里下图所示的tile开启S/4HANA for Customer Management的旅程:
对于使用过SAP CRM的朋友来说,接下来都是熟悉的味道。如果后台用户profile里将参数CRM_UI_PROFILE的值维护为*,就能够在下图的登录界面里看到所有可供选择的业务角色:
现在我用角色S4C_SRV_ICAG登入系统, 跑一个呼叫中心相关的场景。
假设一位名叫Jerry的客户打电话到呼叫中心,就他购买的一款ID为11的产品提出了服务请求。
座席接到电话,首先确认Jerry的身份:可以根据Jerry提供的在系统中的Account ID或是其他的联系方式,比如手机号码,邮箱地址等等(支持的所有方式如下图Identify Account区域内的字段所示)。这里座席采用的方式是根据Account ID来确认身份。
座席输入Jerry提供的Account ID,点击Search Account按钮:
选中搜索结果,点击Confirm按钮。
然后根据Jerry提供的产品ID 11, 将这个产品搜索出来,点击工具栏的创建按钮,基于该产品创建一个服务订单。
这是最终生成的订单一览:
我的公众号后台收到很多朋友的留言,询问关于这个产品的种种细节。这里就我能够回答的问题一一解答。
1. S/4HANA for Customer Management的UI是用什么技术开发的?
答:用的仍然是SAP CRM WebClient UI,而不是SAP UI5。对于熟悉CRM WebClient UI开发技术的朋友们来说,这是一个好消息,意味着大家以前在这项开发技能上投入的时间没有白费,可以继续在S/4HANA上发光发热。而对那些想学习新的UI开发技术的朋友们来说,S/4HANA的CDS View+Smart Template这一组合,也给大家充分提供了使用新技术的机会。大家如果想尝试Smart Template,可以参考我的微信公众号文章: Jerry的通过CDS view + Smart Template 开发Fiori应用的blog合集, 里面包含了一些具体的例子。
2. S/4HANA for Customer Management里的销售和服务流程,和SAP CRM的对应流程相比有何区别?
答: 至少在目前已经发布的1.0版本里,前者是后者的一个子集。后续版本会在S/4HANA里引入更多在SAP CRM里支持的销售和服务功能。
3. 接问题2: 同样的业务流程,S/4HANA for Customer Management里的技术实现,和SAP CRM相比有何区别?
答: 同一个功能,比如物料主数据的搜索,虽然从最终用户眼中看起来都是在同样的UI上点击搜索按钮而已,但技术上的实现在这两个产品里是不同的。差异主要体现在下图中绿色区域的Generic Interaction层和更底层的数据模型,以及围绕这些数据模型进行CRUD(增删读改)操作的API。
数据库表的更改最易理解,在这两个产品里有很多从业务上说实际上描述的是同一概念的模型,比如SAP CRM的Product(产品)和S/4HANA里的Material(物料)。在CRM里我们用事务码COMMPR01创建产品, 其相关数据存储在以COMM_开头的一系列表里。而S/4HANA则是在事务码MM01里创建物料, 数据存储在主表MARA和一系列从表里。
上述描述反映了这样一种情况:在SAP CRM和S/4HANA分别用不同的技术模式描述业务上同一个概念。针对这种情况,在将SAP CRM的销售和服务流程引入S/4HANA的过程中,我们面临着模型的取舍问题。我们采用的准则是:使用S/4HANA的模型。
这就意味着在S/4HANA for Customer Management里,之前SAP CRM里使用的API也需要做相应的调整,这些API里对SAP CRM数据模型的操作需要重定向到S/4HANA对应的数据模型。
举一个具体的例子:
以存储物料的数据库表为例。本文前部在介绍S/4HANA for Customer Management的外观部分提到了ID为11的产品,在SAP CRM里我们是去表COMM_PRODUCT里根据PRODUCT_ID来找到该产品。而在S/4HANA里则需要去表MARA里找。
值得一提的是,在这款新产品的开发过程中,我们并不是简单地将代码里所有使用到SAP CRM数据模型的地方都找出来,替换成S/4HANA的数据模型而已。我们做了很多基于S/4HANA架构的优化,目的是充分发挥S/4HANA系统底层提供的强大功能和各种创新技术。
一个具体例子就是本文开头提到的产品搜索功能。这个功能是SAP成都研究院开发团队负责实现的。SAP CRM产品搜索的底层实现是基于数据库表COMM_PRODUCT的。而在S/4HANA for Customer Management里,我的同事们并没有简单照搬思路直接去查S/4HANA物料数据库表MARA,而是采用了S/4HANA的新的建模方式,设计了一个CDS view。当用户点击了搜索按钮后,底层的执行会搜索下图这个CDS view。
借助CDS view,我们遵循了S/4HANA建模领域里耳熟能详的准则"Code Push Down", 确保了尽可能多的逻辑直接在数据库层面执行, 充分发挥SAP HANA强大的数据处理能力。
如果大家对S/4HANA里CDS view这一重要的建模方式感兴趣的话,可以阅读这篇SAP Community上访问量过2万的CDS View概述文章:
ABAP Core Data Services – Introduction (ABAP CDS view)
https://blogs.sap.com/2017/09/09/abap-core-data-services-introduction-abap-cds-view/
如果想深入了解CDS view的一些技术细节,请参考我的微信公众号文章:Jerry的CDS view自学系列,里面包含了14篇文章,全是我自己通过阅读CDS框架源代码和调试的方式了解到的一些技术实现细节,以及我做过的一些例子和工具。
4. S/4HANA for Customer Management里的One Order模型,和SAP CRM里的模型相比有何改进?
答:有很多改进,Jerry去年在德国SAP总部吃了3个月的土豆+面包,就是在做这件事情。
在SAP CRM里,一个订单的数据散落在不同的数据库表里,大家最熟知的,就是存放抬头信息的CRMD_ORDERADM_H和存放行项目信息的CRMD_ORDERADM_I这两张表。其名称中的ADM(Administration)是一个提示:订单的绝大部分业务数据并没有存储在这两张表里,而是位于其他的专属表里。
如下图所示,图中不同颜色的矩形框代表One Order模型里不同类型的节点,每个节点拥有一个专属的数据库表,这些节点之间可能包含从属关系,这些从属关系又维护在下图正中的数据库表CRMD_LINK里。
所有这些数据库表加起来有200多个。这套数据模型在传统的Transaction应用领域里被证明是非常成功的:SAP CRM广泛应用于全球众多客户群的事实说明了一切。而在Analytics使用场景下,上述数据模型需要和另一个模型,就是CRM顾问们熟知的索引表CRMD_ORDER_INDEX协同工作。
顾名思义,这张表的引入是一个以空间换时间的策略——索引表存放了部分来自业务数据表里的数据,以部分冗余的存储空间为代价来减少进行Analytics计算所花费的时间。
而在S/4HANA for Customer Management里,One Order的底层存储模型得到了大幅简化。一个订单所有的抬头级别的数据,例如订单编号,描述信息,类型,创建者,创建时间,发货方,收货方等等都存储在一个新的数据库表CRMS4D_SERV_H里。
而对应的行项目信息,则存放于表CRMS4D_SERV_I里。
基于这种扁平结构的数据表上构造出来的CDS view,能够最大程度上减少为了抽取数据用于Analytics场景所需要进行的数据库表之间的连接操作,充分发挥出S/4HANA强劲的数据处理能力,也从根本上避免了索引表的引入造成的存储空间浪费。
从用户的角度上说,S/4HANA加上CDS view这对组合,就是Analytics场景下最好的性能保证。
从架构的角度上说,S/4HANA的销售和服务这块业务的Transaction和Analytics应用,使用了同一套新的数据模型,相比SAP CRM On Premise的众多业务专属表+CRMD_LINK+CRMD_ORDER_INDEX的设计有了大幅简化。更重要的是,CDS view的引入,使得S/4HANA for Customer Management能够受益于SAP在CDS view这一领域内的持续创新。
从Partner的角度上说,底层模型的简化,也降低了Partner排错的复杂度。同时,感谢之前SAP CRM里One Order API优雅的分层设计——上文描述的底层存储模型的改动,没有影响到One Order API的接口。这意味着如果之前您已经能够在SAP CRM里熟练运行CRM_ORDER_MAINTAIN和CRM_ORDER_SAVE这些API进行二次开发,那么您在S/4HANA for Customer Management从事和One Order相关的二次开发也没有任何问题——这些API的用法没有任何改变。
5. 我是一位SAP CRM开发顾问。我将来会失业么?
答:如果您有耐心读到这里,相信您心中已经有了答案。
一方面,在S/4HANA for Customer Management里,二次开发使用到的技术, 前台仍然是CRM WebClient UI,加上后台的One Order系列的API,这使得大家之前在这一领域多年的技术积累没有白费。另一方面,这个新的产品因为是运行在S/4HANA这一SAP旗舰级产品上,这就给每一位希望学习S/4HANA的CRM顾问打开了一扇门。
我自己有一个感受,学习一项新技术,或是一个新产品,在工作和实战中学习,其效率和知识掌握的深度都要超过在业余时间看看资料这种学习方式。S/4HANA for Customer Management的问世,给每一位CRM顾问提供了更大的舞台,让大家不仅能继续在销售和服务领域深耕,同时也能在工作中学习S/4HANA,我个人认为这是一个很好的发展机会。
因为Jerry还在S/4HANA for Customer Management的项目里继续进行后续版本的开发,所以将来这个公众号会带来更多关于这个产品的介绍文章。
如果大家还有关于这个产品的其他问题,请在这篇文章做出评论或者直接在后台给我留言。如果大家想成为SAP成都开发团队的一份子,和我们一起努力让S/4HANA for Customer Management变得更好,请发送消息到这个公众号的后台通知我。我会和您联系。