Salesforce使用truncate清空数据库
2017-01-30 09:38
316 查看
如果想快速的清空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
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
相关文章推荐
- mysql 协议的processInfo命令包及解析
- 编译安装mysql5.6并初始化数据库和创建系统服务
- nodejsmysqlconnectiontutorial
- SQL 共享之 ROLL_INVALID_MISMATCH 含义
- Oracle Index Merge 与 and_equal 的变迁
- centos6.5 安装redis3.0.7
- nginx+Redis+tomcat实现session共享的过程
- SpringBoot缓存注解学习笔记之Redis
- ehcache memcache redis 三大缓存对比
- 谈一谈redis集群(二)
- mysql更改数据存储地址
- 习课的redis配置记录
- 后台(03)——MySQL(3)
- sqlmap --tamper 绕过WAF脚本分类整理
- mysql-ERROR 2002 (HY000)
- MySQL学习笔记-用户管理例子
- MySQL2
- 根据从表数据修改主表的值
- 【牛腩新闻发布系统】SQL注入
- flask扩展模块flask-sqlachemy 的使用---mysql数据库