salesforce零基础学习(一百三十四)State And Country/Territory Picklists启用后的趣事

发布时间 2023-11-30 22:17:27作者: zero.zhang

本篇参考: https://help.salesforce.com/s/articleView?id=sf.admin_state_country_picklists_overview.htm&type=5

背景:提起 State And Country/Territory Picklist这个功能,想必大部分人都不会陌生,其好处是可以让用户更好的选择Country以及State的信息,而不是用户手填,这可以很大程度上保证数据质量,针对后续的Report/Dashboard的数据过滤也会更友好,并且针对集成平台,也可以更好的沟通。 下图中的Address是一个compound field,其中就包括了 Country 和State。

 为了方便后续内容的展开,我们先对Lead表创建一个Trigger,针对Before Update / After Update打出一下Trigger.new 以及Trigger.old日志内容。

trigger LeadTrigger on Lead (before update, after update) {
    if(Trigger.isUpdate) {
        if(Trigger.isBefore) {
            system.debug('*** before Trigger.new : ' + JSON.serializePretty(Trigger.new));
            system.debug('*** before Trigger.old : ' + JSON.serializePretty(Trigger.old));
        } else if(Trigger.isAfter) {
            system.debug('*** after Trigger.new : ' + JSON.serializePretty(Trigger.new));
            system.debug('*** after Trigger.old : ' + JSON.serializePretty(Trigger.old));
        }
    }
}

我们在启用功能以前,大家可以猜到如何运行,这里不再做测试,接下来我们进行展开,这里先启用中国和美国以及相关的城市或者州。启用步骤可以基于上方的参考链接,因为这个不是本篇重点,所以暂不演示,直接跳到成功画面。通过下图中,我们可以看到Country以及State已经配置完成。

 我们对Country以及State字段进行修改。从 China -> Beijing修改成 United States -> New York.

我们通过Debug Log获取主要的一些信息,其他不重要的信息省略。

*** before Trigger.new :

[ {
  "StateCode" : "NY",
  "State" : "Beijing",
  "Country" : "China",
  "Id" : "00Q5g00000SfwnHEAR",
  "LastName" : "test",
  "CountryCode" : "US"
} ]

*** before Trigger.old :

[ {
  "StateCode" : "11",
  "State" : "Beijing",
  "Country" : "China",
  "Id" : "00Q5g00000SfwnHEAR",
  "LastName" : "test",
  "CountryCode" : "CN"
} ]

*** after Trigger.new : 

[ {
  "StateCode" : "NY",
  "State" : "New York",
  "Country" : "United States",
  "Id" : "00Q5g00000SfwnHEAR",
  "LastName" : "test",
  "CountryCode" : "US"
} ]

*** after Trigger.old : 

[ {
  "StateCode" : "11",
  "State" : "Beijing",
  "Country" : "China",
  "Id" : "00Q5g00000SfwnHEAR",
  "LastName" : "test",
  "CountryCode" : "CN"
} ]

我们基于上方的log可以看到,尽管我们已经从 China -> Beijing 修改成了 United States -> New York,然而Before Trigger中的Trigger.new却呈现出了很迷惑的操作,如果程序中使用 Country/ State作为判断逻辑,当启用这个功能会造成很大的问题,因为Country / State在before的节点,值是错的,其他的节点是正确的。 所以实际项目中,如果启用这个功能,一定要检查当前系统中是否有trigger的before是否有针对这个字段的逻辑,如果有,需要修改成 CountryCode和StateCode,否则会造成逻辑问题。

总结:翻了一下官方文档,目前没有说过这个Consideration/Limitation,估计是一个bug。有用到的或者即将用到的朋友注意这点就好。篇中有错误的地方欢迎指出,有不懂的欢迎留言。