使用JCo同步SAP系统数据

本文介绍了一种业务系统与SAP系统间财务数据的同步方案,通过定时任务使用JCO连接SAP并获取更新数据,利用Spring的Quartz进行任务调度。实现了数据的高效同步及前端展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、
项目需求

业务系统需要调用SAP系统的财务相关功能,调用时需要提供其所需的专有参数,如公司、科目,而这些参数都将作为可选项存在,有的可能存在上千项,如某公司下有上千个费用科目,如果每次调用时都实时链接SAP获取这些可选项数据,将给业务系统的性能造成影响,因此需要在业务系统上保存这些数据。
二、
项目分析

提供SAP系统财务相关功能所需的参数多为短时间内变化量不大的数据,如:公司、科目,在时效性上没有要求,新添加了一个科目,第二天在业务系统上才有更新可以被用户接受,因此,可以先将所需数据一次性全部保存到业务系统,然后定时同步有变化的数据。而业务系统读取这些数据时,只需要再编写js脚本对外提供以指定格式显示的函数即可。
三、
系统设计

数据由SAP系统所有,因此应该由SAP提供函数,定时执行,提供有变化的数据,提交到业务系统,业务系统根据SAP提供的数据,更新自己已经保存的数据。因此首先想到使用WebService方式,由业务系统提供服务,接受XML格式的数据,更新自己的数据。但是经测试SAP系统支持的WSDL文件规范比较低,在SAP系统中添加WebService时,业务系统提供的WSDL文件并不能为SAP系统所识别。所以,采用业务系统定时使用Jco链接SAP,执行RFC函数,获得有变化的数据(RFC函数获取有变化的数据,拼成可保存为XML文件的字符串),更新自己的数据的方式。这里使用SpringQuartz来作为任务调度器,定义同步数据为一个Job,定义每隔一定时间为一个Trigger(定时触发)。
四、
程序编写

1.
启动程序

com/sap/jco/SpringSchedule.java
在此文件中加载Spring配置文件,启动应用
2.
bean.xml
定义了Quartz任务调度器的实现类schedule,定义此调度器的触发器为simpleTrigger,在此bean中设置了触发器的启动时间和执行间隔,当然,也可以使用org.springframework.scheduling.quartz.CronTriggerBean,其可以设置具体在什么时间执行(视项目情况选取合适的Trigger),定义此调度器的Job为methodInvokingJobDetail,在这个Job中使用继承了TimerTasksyncTask中的start方法。
3.
真正的Job
com/sap/jco/SyncTask.java
start()中执行writeService.write(readService.read());
4.
链接SAP
com/sap/jco/util/JCOUtils.java
根据sapBean中配置的参数执行链接,并提供创建指定名称函数、执行指定函数对象的方法
注意:将库文件libsapjco3.so放在$JAVA_HOME/jre/lib/i386目录下
5.
获取数据
com/sap/jco/dao/impl/ReadManagerImpl.java
根据sapbean.xml中装配的sapBean链接SAP系统,创建函数,执行,从返回结果中获取指定名称的信息,并以名称值为key存储到HashMap中
6.
更新数据
com/sap/jco/dao/impl/WriteManagerImpl.java
从HashMap中根据key得到对应的信息,将此信息保存为XML文件,分别从保存原有信息和新信息的XML文件中得到beanList,然后与原有的数据做对比,如果新信息操作标示为“D”,则在原有信息中按照主键查找,如果存在,从原有数据中删除;如果新信息操作标示为“U”,则在原有信息中按照主键查找,如果存在,从原有数据中先删除记录,再添加新纪录;如果信息操作标示为“I”,则直接插入。操作完成后将已经有变化的信息重新写入文件。
7.
js脚本获取数据
参见js/funcForSAPData.js
五、
系统测试

经测试,可以达到预期效果。
六、
优缺点分析

优点:
同步数据
采用与业务系统松耦合的设计,独立于业务系统运行。
显示数据
使用js脚本从xml文件中获取数据格式化显示,在业务系统需要调用数据的位置添加js函数即可。
缺点:
同步数据
获取到更新的数据进行同步时,在原有数据中按照主键查找时如果不做优化,当数据量比较大时可能会影响性能。
显示数据
如果业务系统中调用数据的逻辑比较复杂,可能会导致js脚本量大量增加,为可读性和可维护性带来困难。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值