如果想快速的清空MySQL中的表,可以使用Truncate命令。
Truncate能够快速的,对数据进行无差别的清空。
在Mysql中使用truncate的语法是
TRUNCATE TABLE [Table Name];
在Salesforce中同样提供了Truncate功能。不过只是提供一个按钮,并不提供任何代码及API调用Truncate的方式。
所以正确的应用场景,应该只是用来快速的清空临时数据或者测试数据。毕竟,无论使用Batch还是dataloader来删除全部数据都要花费大量的时间。
在Salesforce中想要看到Truncate按钮的话,需要达成如下条件,参考官方文档:
- Profile -> Administrative Permissions -> Customize Application -> True
- User Interface -> Setup -> Enable Custom Object Truncate -> True
然后在到Custom Object的详细画面,就能看到在Edit,Delete按钮旁边Truncate按钮出现了。
不过,并不是任何Object任何情况都能进行Truncate,有如下要求,参考官方文档:
- 不能被别的Object Lookup,或者处在Master-Detail中的Master地位。
- 不能被Report Snapshot参照。
- 不能有自定义字段是Index或者是External ID。
- 不能开启了skinny table。(关于Skinny Table的事情会另外写一篇)。
为什么会有如上的限制,显而易见,与Salesforce中Truncate的动作有关。
在Salesforce中,虽然Truncate功能与MySQL类似,用来清空表中的数据,但是会导致Custom Object的Id Prefix产生变化。所以所有通过三位Id Prefix引用此Custom Object的功能都会失效。如果Apex/VF/Button中有直接使用3位Id Prefix进行判断的逻辑,就会受到影响。
除此之外,另一点与MySQL不用的是,如果有一个自增字段。MySQL在Truncate后,会重置自增字段的计数器。而Salesforce则不会。没错,虽然ID变了,但自增字段会接着数并不会重新回到起始值。