1.查询一个对象下所有字段
当需要查询一个对象所有字段进行复制或其他操作,可以使用一段拼接的语句来查询
 String query = 'select ';
for(String fieldApi : Schema.SobjectType.Opportunity.fields.getMap().keySet()){
if(fieldApi=='Id')
continue;
query += fieldApi + ', ';
}
query += 'Id from Opportunity';
System.debug(query);

2.获取记录类型的几种方式

 //第一种
String recordType = Schema.SObjectType.Good__c.getRecordTypeInfosByName().get('中端品牌').getRecordTypeId();
system.debug('第一种:' + recordType);
//第二种:
List<RecordType> list_type = [Select id,Name,IsActive,DeveloperName FROM RecordType where Name = '奢侈品牌' and IsActive = true];
System.debug('第二种:' + list_type); //第三种
List<RecordType> list_type3=[select Id,DeveloperName,Name from RecordType where (DeveloperName='MiddleBrand' OR DeveloperName='extravagant')
AND SObjectType='Good__c'];
System.debug('第三种:' + list_type3); //第四种
List<RecordType> list_type2 = [Select Id,Name,DeveloperName From RecordType where sobjecttype = 'Good__c'];
System.debug('第四种:' + list_type2); //************************************************************************************************************ /*********
*
* @function
* 传入对象名,获取一个Map<对象记录类型id,对象记录类型名>
*
*
*/
public static Map<ID,RecordType> getObjectRecordType(String objectName){ Map<ID,RecordType> RecordTypeMap = new Map<ID,RecordType>([
SELECT
Id,DeveloperName
FROM
RecordType
WHERE
SObjectType =: objectName
]); return RecordTypeMap;
}
 
3.List<sobject>与JSON串的转换
 String json_String = JSON.serialize(List<Opportunity> list_object);
List<Opportunity>)JSON.deserialize(String json_String, List<Opportunity>.class);

提供一个工具网站,将JSON自动转换成Apex类:JSON to Apex

4.BASE64位与MD5加密

 // base64Encode:base64编码
String AccountId = 'X66666694292';
String mytime = Datetime.now().format('yyyyMMddHHmmss');
String authorizationHeader = EncodingUtil.base64Encode(Blob.valueOf(AccountId + ':' + mytime));
System.debug('authorizationHeader:' + authorizationHeader); //sig的值为 32位大写MD5加密 (帐号Id + 帐号APISecret +时间戳)
String sig = AccountId + APISecret + mytime;
String token = EncodingUtil.convertToHex(Crypto.generateDigest('MD5', Blob.valueOf(sig))).toUpperCase();

5.订单产品页面布局调整

调整标准的订单产品添加页面字段,调整后预览如下

修改订单产品页面布局右上方下的多行式项目布局即可

6.自定义标签提示错误信息

通过自定义标签创建一条提示消息

然后在trigger里面判断,如果不满足条件可以抛出这条错误消息。效果如下图

对应的代码,其实可以看到提示消息就是一个字符串,但是使用自定义标签能够支持配置提示消息。

 trigger OpportunityTrigger on Opportunity (after insert) {

      if(trigger.isInsert && trigger.isAfter){
for(Opportunity opp:trigger.new){
opp.addError(Label.Opp_Machine_Approval);
}
}
}

7.自定义设置没有列表

在方案设置中开启列表类型

开启后预览效果

8.生成随机数

发现Salesforce没有比较顺手的随机数生成方法,自己写了一个功能函数备用

 // @size 0-size范围的随机数
public static Integer getRandomNumber(Integer size){
return ((math.random()) * size).intValue();
} // @size 【lowerValue,upperValue】 范围的随机数
public static Integer getRandomNumber(Integer lowerValue,Integer upperValue){
return (math.random() * (upperValue - lowerValue + 1 ) + lowerValue).intValue();
}

9.自定义提交待审批按钮

按钮实现JS代码

 {!REQUIRESCRIPT("/soap/ajax/35.0/connection.js")}
{!REQUIRESCRIPT("/soap/ajax/35.0/apex.js")} var recordtype = '{!Opportunity.RecordType}';
var status = '{!Opportunity.ApprovalStatus__c}';// 审批状态
var stage = '{!Opportunity.StageName}'; if(recordtype != '需要的记录类型'){
alert('当前业务机会记录类型为:' + recordtype + '不能使用该审批!');
}else if(status == '审批中'){
alert('当前业务机会正在审批中,请耐心等待审批结果!');
}else if(status == '已通过'){
alert('当前业务机会已审批通过,请不要重复提交');
}else{
var request = new sforce.ProcessSubmitRequest();
request.objectId = "{!Opportunity.Id}";
var processRes = sforce.connection.process([request]);
if(processRes[0].getBoolean('success')){
alert("已提交报价审批,请等待审批完成!");
window.location.reload();
}else{
alert("提交审批错误:" + processRes[0].errors.message);
}
}

需要注意的,是保证对审批流条件的控制,虽然不做控制系统也会自动识别该选择那条审批流,但是这样没办法友好的提示用户有那些条件是审批必须要满足的

 10 删除Chatter数据

 List<FeedItem> list_feed = new List<FeedItem>([select id from FeedItem]);
delete list_feed;

 11 正则表达式拆分中英文

 String str = '123中文英文Englist通过正则@#!!进行&^%拆分';
System.debug('规格型号:' + str.replaceAll('[\u4E00-\u9FA5]',' '));
System.debug('名称:' + str.replaceAll('[^\u4e00-\u9fa5]',''));

拆分后预览

12 事件不超过24H限制解除

错误消息:

Duration must be between 0 and 1440 minutes - Salesforce Error - [FIELD_INTEGRITY_EXCEPTION]

Salesforce 开发整理(九) 开发中使用的一些小技巧汇总[持续更新]的更多相关文章

  1. jquery小技巧汇总 持续更新中

    1.jquery高亮当前选中菜单 $("document").ready(function(){ $(".menu li").click(function(){ ...

  2. iOS 开发中使用到的小技巧汇总

    国庆即将来到,一个小项目也即将完成,把自己在项目中用的一些小技巧写出来,方便查找. 1,去掉分割线--动画设置透明度alpha //去掉tableView的分隔线:     self.tableVie ...

  3. selenium webdriver使用的一些小技巧(持续更新中)

    1.开始结束时间只支持控件选择,不支持填写,怎么办? 如下图: 解决方案: 用javaScipt把开始结束时间的reaonly属性去除,然后再输入,举例如下 /**     * 输入开始日期     ...

  4. 【MySQL】日常小技巧汇总,更新中……

    创建表时修改自增主键,添加 AUTO_INCREMENT=<Number> ,例如: CREATE TABLE `table_name` ( `id` int(11) unsigned N ...

  5. Windows Phone开发(8):关于导航的小技巧

    原文:Windows Phone开发(8):关于导航的小技巧 前文用几个例子对导航做了简单介绍,在一般应用中,使用上一篇文章中说到的方法,其实也够用了,不过,为了能够处理一些特殊的情况,有几个小技巧还 ...

  6. 《WCF技术剖析》博文系列汇总[持续更新中]

    原文:<WCF技术剖析>博文系列汇总[持续更新中] 近半年以来,一直忙于我的第一本WCF专著<WCF技术剖析(卷1)>的写作,一直无暇管理自己的Blog.在<WCF技术剖 ...

  7. 中国.NET:各地微软技术俱乐部汇总(持续更新中...)

    中国.NET:各地微软技术俱乐部汇总(持续更新中...)   本文是转载文,源地址: https://www.cnblogs.com/panchun/p/JLBList.html by ​史记微软. ...

  8. IDEA Intellij中vim插件使用小技巧

    在 IDEA Intellij小技巧和插件 一文中简单介绍了一下IdeaVim插件.在这里详细总结一下这个插件在日常编程中的一些常用小技巧.供有兴趣使用这个插件,但对Vim还不十分熟悉的朋友参考.当然 ...

  9. [转]Golang 中使用 JSON 的小技巧

    taowen是json-iterator的作者. 序列化和反序列化需要处理JSON和struct的关系,其中会用到一些技巧. 原文 Golang 中使用 JSON 的小技巧是他的经验之谈,介绍了一些s ...

随机推荐

  1. telnet 发送邮件

    telnet smtp.aliyun.com 25 // 这里用的是阿里云的smpt服务器,并且开放25端口 helo hi // 和阿里云的smtp服务器打招呼,测试是否连通 auth login ...

  2. mybatis批量更新出现he error occurred while setting parameters

    当你更新一条时,不会发生问题,但是执行多条就出现了错误原因是mysql 配置jdbc:driver 应该添加&allowMultiQueries=trueurl:jdbc:mysql://lo ...

  3. RSyslog Windows Agent 安装配置

    下载地址:https://www.rsyslog.com/windows-agent/windows-agent-download/ 安装过程: 1.双击rsyslogwa安装包,开始进行安装 2.一 ...

  4. 图灵的文章“Computing machinery and intelligence”译文

    图灵奠基AI的力作“Computing  machinery and intelligence”全文译完,摘自http://blog.sciencenet.cn/blog-2322490-112266 ...

  5. Spring Data Jpa:分页、Specification、Criteria

    分页的主要接口与类 PagingAndSortingRepository 继承自 CrudRepository 接口,提供了排序以及分页查询能力,提供了两个方法 Iterable<T> f ...

  6. iOS处理含中文的请求链接

    NSString *urlStr = @""; // 将中文URL进行转码 urlStr = [urlStr stringByAddingPercentEscapesUsingEn ...

  7. SQL Server 使用union all查询多个条件数据合并分组显示,同比统计

    ),a.created_yearmonth,) created_yearmonth, a.countaccount countaccount, a.yxsl yxsl, a.sccdsl sccdsl ...

  8. Linux Workqueue【转】

    转自:http://kernel.meizu.com/linux-workqueue.html 21 August 2016   Workqueue 是内核里面很重要的一个机制,特别是内核驱动,一般的 ...

  9. K8s集群中设置harbor仓库认证

    一,获取harbor的登陆用户名和密码(demo_user/demo_pwd) 二,使用kubectl命令生成secret(不同的namespace要分别生成secret,不共用) kubectl c ...

  10. Ubuntu下部署Shipyard管理docker

    使用k8s对于我这种新人来说,难度有点大.遂尝试使用Shipyard这个docker web ui工具来进行管理,以方便入门. 首先,我们还是需要在我们的主机上安装docker. 然后官方提供了自动安 ...