假设系统里已经有许多的Lead历史数据,而我们正在进行的微信小程序和C4C集成的项目里,又创建了许多新的Lead数据。如何将这些新的在微信小程序里调用OData服务创建的Lead数据同老的历史数据做区分呢?
(1) 在C4C Sales Lead页面里,通过Source字段来标明Lead的来源。
data:image/s3,"s3://crabby-images/716c9/716c9490ff7383cf7f342ec4c6043f1cedb118e1" alt=""
对于AI Card项目来说,所有的Lead经由微信小程序创建,因此调用OData API时,SourceCode指定为“Wechat Social Channel”的代号:Z01
data:image/s3,"s3://crabby-images/66b99/66b990a7a90bfdaf54d8be516129b7e7fd20ee8a" alt=""
这样,在读取操作时,使用inlinecount=allpages,能一并返回SourceCode为Z01的Lead一共有多少个。
最后的url如下:
https://my500.c4c.saphybriscloud.cn/sap/c4c/odata/v1/c4codata/LeadCollection?inlinecount=allpages
结果如下:
data:image/s3,"s3://crabby-images/96f66/96f661cb2578e823bc6d60c1d742721a71e318dc" alt=""
截至2020年3月20日12:23PM为止,在系统上经由微信小程序创建,Source Code字段为Z01的Lead总共有6个。
data:image/s3,"s3://crabby-images/8e4cc/8e4cc98735621f1636ddba5a5778ee231be31f42" alt=""
如果系统里满足这个条件的Lead越来越多,调用OData服务后,会造成规模巨大的数据量从服务器发送往消费端,所以建议使用客户端分页方式读取数据。
首先获取满足SourceCode为Z01的lead个数:
https://my500.c4c.saphybriscloud.cn/sap/c4c/odata/v1/c4codata/LeadCollection/filter=SourceCode eq 'Z01'
data:image/s3,"s3://crabby-images/006f0/006f04e54debe990ca3e06c2378b6e10eca21606" alt=""
假设返回结果数为1000, 我们可以在客户端进行分页读取,每页读取的个数可以客户端自行决定,比如每次读取20个。
第一页的读取请求:
https://my500.c4c.saphybriscloud.cn/sap/c4c/odata/v1/c4codata/LeadCollection?orderby=CreatedOn desc&$top=20
20个Lead返回:
data:image/s3,"s3://crabby-images/06a9f/06a9f83af69f0ed1b67e3fd467cf0688a44b7120" alt=""
第二页:即第21到第40个:
https://my500.c4c.saphybriscloud.cn/sap/c4c/odata/v1/c4codata/LeadCollection?orderby=CreatedOn desc&
top=20
第三页:即第41个到第60个
https://my500.c4c.saphybriscloud.cn/sap/c4c/odata/v1/c4codata/LeadCollection?orderby=CreatedOn desc&
top=20
要获取更多Jerry的原创文章,请关注公众号"汪子熙":
data:image/s3,"s3://crabby-images/dbdb5/dbdb58b6e07a167b4c721ac53e4d5857cad20da6" alt=""
网友评论