• Salesforce使用truncate清空数据库


    如果想快速的清空MySQL中的表,可以使用Truncate命令。
    Truncate能够快速的,对数据进行无差别的清空。

    在Mysql中使用truncate的语法是
    TRUNCATE TABLE [Table Name];

    在Salesforce中同样提供了Truncate功能。不过只是提供一个按钮,并不提供任何代码及API调用Truncate的方式。
    所以正确的应用场景,应该只是用来快速的清空临时数据或者测试数据。毕竟,无论使用Batch还是dataloader来删除全部数据都要花费大量的时间。

    在Salesforce中想要看到Truncate按钮的话,需要达成如下条件,参考官方文档:

    1. Profile -> Administrative Permissions -> Customize Application -> True
    2. User Interface -> Setup -> Enable Custom Object Truncate -> True


    然后在到Custom Object的详细画面,就能看到在Edit,Delete按钮旁边Truncate按钮出现了。

    不过,并不是任何Object任何情况都能进行Truncate,有如下要求,参考官方文档:

    1. 不能被别的Object Lookup,或者处在Master-Detail中的Master地位。
    2. 不能被Report Snapshot参照。
    3. 不能有自定义字段是Index或者是External ID。
    4. 不能开启了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变了,但自增字段会接着数并不会重新回到起始值。

    海外同步地址:https://wp.me/p3i9xe-bG

  • 相关阅读:
    nginx 阻止ip访问
    mysql sql语句性能分析
    SWFUpload demo
    XSHELL win7 和 linux 系统之间文件互传
    基于HTTP协议的轻量级开源简单队列服务:HTTPSQS
    The following packages have been kept back
    php 错误日志记录
    TWIG 分页宏(基于 bootstrap)
    gitconfig 全局配置文件。
    简单的图片异步上传代码
  • 原文地址:https://www.cnblogs.com/sfdc/p/6351252.html
Copyright © 2020-2023  润新知