zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    团队任务拆解
    团队贡献分分配规则
    使用highcharts绘制美观的燃尽图
    【Alpha】阶段第一次Scrum Meeting
    项目功能规格说明书
    技术规格说明书
    软件工程团队第二次作业
    软工第一次团队作业
    团队作业 # 项目功能规格说明书
    团队作业 #2 —— 项目选择
  • 原文地址:https://www.cnblogs.com/sfdc/p/6351252.html
Copyright © 2011-2022 走看看