本篇参考: 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。有用到的或者即将用到的朋友注意这点就好。篇中有错误的地方欢迎指出,有不懂的欢迎留言。

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

  1. salesforce 零基础学习(三十四)动态的Custom Label

    custom label在项目中经常用到,常用在apex class或者VF里面用来显示help text或者error message.有的时候我们需要用到的信息是动态变化的,那样就需要动态来显示信 ...

  2. salesforce 零基础学习(二十四)解析csv格式内容

    salesforce中支持对csv格式的内容批量导入,可以使用dataloader,然而有些情况下,当用户没有相关权限使用dataloader导入情况下,就的需要使用VF和apex代码来搞定. 基本想 ...

  3. salesforce 零基础学习(三十九) soql函数以及常量

    在salesforce中,我们做SOQL查询时,往往需要用到计算式,比如求和,求平均值,或者过滤数据时,往往需要通过时间日期过滤,SOQL已经封装了很多的函数,可以更加方便我们的sql查询而不需要自己 ...

  4. salesforce零基础学习(八十四)配置篇: 自定义你的home page layout

    当我们进入salesforce系统或者切换app后,默认第一个看到的就是home页面.home页面简单的来说可以包括左侧(narrow component)和右侧(wide component)两部分 ...

  5. salesforce 零基础学习(三十六)通过Process Builder以及Apex代码实现锁定记录( Lock Record)

    上一篇内容是通过Process Builder和Approval Processes实现锁定记录的功能,有的时候,往往锁定一条记录需要很多的限制条件,如果通过Approval Processes的条件 ...

  6. salesforce 零基础学习(六十四)页面初始化时实现DML操作

    有的时候我们往往会遇到此种类似的需求:用户在访问某个详细的记录时,需要记录一下什么时候哪个用户访问过此页面,也就是说进入此页面时,需要插入一条记录到表中,表有用户信息,record id,sObjec ...

  7. salesforce 零基础学习(五十四)常见异常友好消息提示

    异常或者error code汇总:https://developer.salesforce.com/docs/atlas.en-us.api.meta/api/sforce_api_calls_con ...

  8. salesforce 零基础学习(三十八)Translate 的使用(国际化处理)

    本篇参考:http://resources.docs.salesforce.com/200/17/en-us/sfdc/pdf/salesforce_workbench_cheatsheet.pdf ...

  9. salesforce 零基础学习(三十五) 通过Process Builder和Approval Processes锁定记录(Lock Record)

    有的时候我们可能有这样的需求,当某个字段为特定的值情况下,便锁定此条记录,仅允许Profile为System Admin的用户修改或者解锁,其他的用户只能查看此条记录,不能修改此条记录,这种情况下我们 ...

  10. salesforce 零基础学习(三十)工具篇:Debug Log小工具

    开发中查看log日志是必不可少的,salesforce自带的效果显示效果不佳,大概显示效果如下所示: chrome商城提供了apex debug log良好的插件,使debug log信息更好显示.假 ...

随机推荐

  1. 线性关系和非线性关系在.net中的应用

    在数学中,线性关系和非线性关系是描述两个变量之间函数关系的两种不同类型. 线性关系是指两个变量之间可以用一条直线来表示的关系.具体来说,如果存在一个一次函数 y = kx + b,其中k和b是常数,使 ...

  2. [ansible]常用内置模块

    前言 ansible内置了很多模块,常用的并不多,可以通过ansible -l命令列出所有模块,使用 ansible-doc module-name 查看指定模块的帮助文档,例如:ansible-do ...

  3. ArrayList底层原理、线程安全及其相关集合(面试常问)

    一.ArrayList底层原理 1.特点及其原理:ArrayList底层基于数组实现,查找快,增删慢 2.ArrayList底层原理,初始化及调用add()方法添加元素: 默认初始化容量为10 第一次 ...

  4. 让 GPT-4 来修复 Golang “数据竞争”问题 - 每天5分钟玩转 GPT 编程系列(6)

    目录 1. Golang 中的"数据竞争" 2. GoPool 中的数据竞争问题 3. 让 GPT-4 来修复数据竞争问题 3.1 和 GPT-4 的第一轮沟通 3.2 和 GPT ...

  5. Redis专题-秒杀

    Redis专题-并发/秒杀 开局一张图,内容全靠"编". 昨天晚上在群友里看到有人在讨论库存并发的问题,看到这里我就决定写一篇关于redis秒杀的文章. 1.理论部分 我们看看一般 ...

  6. 手把手教你使用Vite构建第一个Vue3项目

    写在前面 在之前的文章中写过"如何创建第一个vue项目",但那篇文章写的是创建vue2的 项目. 传送门如何创建第一个vue项目 打开Vue.js官网:https://cn.vue ...

  7. 我的 Windows 文件管理哲学

    前言   作为一个不合格的 Geek,我经常面临把 Windows 弄崩溃的尴尬处境,我的系统因此重装了一遍又一遍--不过在一次次的重装中,我逐渐总结出了于我个人而言行之有效的文件管理哲学,在此略做总 ...

  8. Centos7安装yarn

    Centos7安装yarn 设置Yarn仓库 curl --silent --location https://dl.yarnpkg.com/rpm/yarn.repo | sudo tee /etc ...

  9. Codechef - Longest AND Subarray(位运算)

    题目大意   给定一个正整数N,其序列为[1, 2, 3, ..., N],找到一个长度最大的连续子列,使得其所有元素取与运算的结果为正(最终输出只需要输出最大长度即可). 思路   刚开始可能并不好 ...

  10. Python面试——基础面试题

    文章目录 1.Python 和 Java.PHP.C.C#.C++等其他语言的对比? C语言既有高级语言的特点,又具有汇编语言的特点,它是结构式语言.C语言应用指针:可以直接进行靠近硬件的操作,但是C ...