Salesforce使用truncate清空数据库
来源:互联网 发布:linux jira安装配置 编辑:程序博客网 时间:2024/05/16 09:03
如果想快速的清空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变了,但自增字段会接着数并不会重新回到起始值。
海外同步地址:https://wp.me/p3i9xe-bG
- Salesforce使用truncate清空数据库
- Salesforce使用truncate清空数据库
- Salesforce使用truncate清空数据库
- truncate 快速清空数据库表
- TRUNCATE TABLE cmd_act_device 清空数据库的一张表
- Linux_Shell 清空cassandra指定数据库的数据 通过 truncate
- sql 使用truncate和delete清空table的区别
- sql 使用truncate和delete清空table的区别
- truncate delete 清空内容
- sql使用truncate和delete清空table的区别(总结)
- 清空数据库日志
- 清空数据库:sp_MSforeachtable
- 清空数据库日志
- 清空数据库日志
- sap 清空数据库
- 清空数据库
- 清空数据库缓存
- 清空数据库日志
- 逆变与协变详解
- removeEventListener('2016');
- Leetcode 63. Unique Paths II
- Quine----输出本身的程序
- The best way to handle the LazyInitializationException
- Salesforce使用truncate清空数据库
- 自定义View 篇二--------《自定义属性》
- java 语句异常后跳出的范围是fun()
- SDWebImage源码解读之干货大总结
- java程序的容错性
- test
- 2017.1.30 Java有感3(main方法)
- Qt学习笔记(一)安装和基本概念
- test2