宝剑锋从磨砺出,梅花香自苦寒来。这篇文章主要讲述在Cloud Flow和Workflow中使用多选选项集类型字段相关的知识,希望能为你提供帮助。
我是微软Dynamics 365 &
Power Platform方面的工程师/顾问罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面的微软最有价值专家(Microsoft MVP),欢迎关注我的微信公众号 MSFTDynamics365erLuoYong ,回复442或者20210513可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!
以前我的博文 Dynamics 365新引入了多选选项集类型字段 简单介绍了Dynamics 365开始引入的多选选项集(MultiSelect Option Set)类型的字段,文章 Copying multi-select option sets in workflows 提到了一些限制如下:
- Cannot be used in the form header
- Cannot be used in the Business Process Flow as a data step
- Cannot be calculated or used by calculated or roll-up fields
- Cannot be used in Bulk editing
- Cannot be used in Business Rules
- 150 options max
- A default value cannot be set
- Cannot be used in the workflow designer
那怎么办?有一种可能可行的办法是借助第三方工具 demianrasko/Dynamics-365-Workflow-Tools ,我没有去尝试。
我用了Power Automate中的Cloud Flow来替换workflow解决的。但是使用时候有坑,需要注意。最值得注意的是Trigger中的提供的字段的值并不包括多选选项集类型字段,我认为这是个BUG。这样给Cloud Flow带来的问题是如果你在Trigger中的Row filter (比如ly_multiselectopitonfield ne null)或者Settings中的Trigger Conditions (比如 @not(empty(triggerBody()?[\'ly_multiselectoptionfield\'])) )利用多选选项集类型字段的值来做判断就会导致问题,因为它的值一直为空。
那如果要用来判断怎么办?也好办,再加个Dataverse Connector的查询步骤,查询下多选选项集字段的值,这个是可以查询出来,查询出来的结果如果有值的话是用逗号隔开的整数。如果要判断这个字段是否有值,可以使用类似的 empty(outputs(\'Get_Multiselectoptionfieldvalue_of_the_contact\')?[\'body/ly_multiselectoptionfieldname\']) 表达式的值 is equal to false来判断,示例如下。
文章图片
查询出来的值是这个样子,是以逗号分隔的数字(选项值),但是其对应的OData.Community.Display.V1.FormattedValue 却是用分号分隔的选项显示文本。
文章图片
【在Cloud Flow和Workflow中使用多选选项集类型字段】如果有值,需要将这个值赋值给别的字段,这个字段用的也是同一个全局选项集的话,直接设置为前面查询获取到的这个字段的值就可以,不需要额外工作,还是不错的。
推荐阅读
- Dynamics 365执行Remove Active Customizations的多种方法
- Dynamics 365中Customer类型字段的使用
- Dynamics 365中表的File数据类型列介绍
- 使用EntityCollection类型和Entity类型的输出参数实例
- 获取用户/团队对某条记录的权限,共享某条记录的某些权限给指定用户/团队的方法
- Dynamics CRM项目实例之十(CRM 2015的捆绑销售在订单中的效果)
- 基本命令学习 -查看文件内容的六种方法
- 介绍Command Checker及重新生成Ribbon元数据的方法
- Linux内核浅入浅出