在Salesforce中,常常要对各种数据进行处理,已满足业务逻辑。本篇文章会介绍如何实现从object获取数据,然后将取得的数据进行一系列简单处理。

第一步:SongName__c 是一个新建的object,向SongName__c  object中插入数据:

/*向表SongName__c插入101条数据*/
public List<SongName__c> CreateData(){
List<SongName__c> songName = new List<SongName__c>();
for(Integer i=0; i<101; i++){
SongName__c a = new SongName__c(Song__c = '歌曲' + i,Contact_email__c ='wicky@sina.com',password__c ='19920122', usage__c = i+100, Active__c = true);
songName.add(a);
} try{
insert songName;
}
catch(DmlException e){
System.debug('An unexpected error has occurred'+e.getMessage());
}
SongName = [Select usage__c FROM SongName__c Where CreatedDate>=2016-10-22T00:00:00+08:00
and CreatedDate<=2016-10-27T00:00:00+08:00 ]; system.debug('插入SongName__c的数据========================'+SongName);
return SongName; }

打印出SongName__c object中的usage__c字段:

14:02:31.2 (505595323)|USER_DEBUG|[59]|DEBUG|......SongName__c.........========================(SongName__c:{usage__c=100, Id=a002800000rlMrEAAU}, SongName__c:{usage__c=101, Id=a002800000rlMrFAAU}, SongName__c:{usage__c=102, Id=a002800000rlMrGAAU}, SongName__c:{usage__c=103, Id=a002800000rlMrHAAU}, SongName__c:{usage__c=104, Id=a002800000rlMrIAAU}, SongName__c:{usage__c=105, Id=a002800000rlMrJAAU}, SongName__c:{usage__c=106, Id=a002800000rlMrKAAU}, SongName__c:{usage__c=107, Id=a002800000rlMrLAAU}, SongName__c:{usage__c=108, Id=a002800000rlMrMAAU}, SongName__c:{usage__c=109, Id=a002800000rlMrNAAU}, ...)

第二步:从 SongName__c 表中获得usage__c 字段(Decimal)的值,并调用快速排序方法将usage__c 字段的值从小到大排序。

/*从Object SongName__c 获得数据,并将获取结果排序*/
public List<Decimal> getData(){
List<SongName__c> SongName=CreateData(); Map<Id, Decimal> SongNameMap = new Map<Id, Decimal>();
for (SongName__c sn: SongName ){
SongNameMap.put(sn.id, sn.usage__c);
} Set <Id> SongNameKey = new Set<Id>();
List<Decimal> songnameValue = new List<Decimal>();
SongNameKey = SongNameMap.keyset();
for(String key: SongNameKey){
songnameValue.add(SongNameMap.get(key));
}
system.debug('GET的数据是======================='+songnameValue);
Quicksort.sortStatic(songnameValue);
system.debug('排序结果======================='+songnameValue);
return songnameValue;
}

快速排序方法:

public class Quicksort  {
private List<Decimal> mNumbers;
private Integer mNumber;
public static void sortStatic(List<Decimal> values){
(new Quicksort()).sort(values);
}//main function
public void sort(List<Decimal> values) { if (values ==null || values.size()==0){
return;
}
this.mNumbers = values;
mNumber = values.size();
quicksort(0, mNumber - 1);
} private void quicksort(Integer low, Integer high) {
Integer i = low, j = high; Decimal pivot = mNumbers[low + (high-low)/2]; while (i <= j) {
while (mNumbers[i] < pivot) {
i++;
} while (mNumbers[j] > pivot) {
j--;
} if (i <= j) {
exchange(i, j);
i++;
j--;
}
}
if (low < j)
quicksort(low, j);
if (i < high)
quicksort(i, high);
} private void exchange(Integer i, Integer j) {
Decimal temp = mNumbers[i];
mNumbers[i] = mNumbers[j];
mNumbers[j] = temp;
}
}

第三步:取usage__c 中最大的3个值和最小的三个值取平均然后乘以常量,常量会以随机方法生成。将结果插入表CustomerUsage__c 的UsageIndex__c字段。 

public  void insertUsage(){
List<Decimal> songnameValue = getData();
sortNum=songnameValue.size();
system.debug('数组长度=================='+sortNum);
averge= (songnameValue[0]+songnameValue[1]+songnameValue[2]+songnameValue[sortNum-3]+songnameValue[sortNum-2]+songnameValue[sortNum-1])/6;
system.debug('平均值========================'+averge);
sum = randomNumber * averge;
system.debug('平均值乘以常量结果========================'+sum);
CustomerUsage__c customnerUsage = new CustomerUsage__c();
customnerUsage.UsageIndex__c=sum;
insert customnerUsage;
}

第四步:在结果插入CustomerUsage__c object 前,会触发一个Triggger,如果随机生成的常量值>0.5就发一封邮件出来,不大于0.5会抛出一个exception出来

 trigger Nov_CustomerUsage_Before_Insert on CustomerUsage__c(before insert){
List<Messaging.SingleEmailMessage> mails = new List<Messaging.SingleEmailMessage>();
for (CustomerUsage__c CU : Trigger.new) {
if (TestUsage.randomNumber != null&& TestUsage.randomNumber > 0.5) {
Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage();
List<String> sendTo = new List<String>();
sendTo.add('weiqi.wang@novartis.com');
mail.setToAddresses(sendTo);
mail.setReplyTo('weiqi.wang@novartis.com');
mail.setSenderDisplayName('Official Bank of Nigeria');
List<String> ccTo = new List<String>();
ccTo.add('weiqi.a.wang@accenture.com');
mail.setCcAddresses(ccTo);
mail.setSubject('您定义的常量大于0.5');
String body = 'Dear ' + ', ';
body += '您定义的常量大于0.5';
mail.setHtmlBody(body);
mails.add(mail);
Messaging.sendEmail(mails);
}
if(TestUsage.randomNumber != null && TestUsage.randomNumber <=0.5){
CU.UsageIndex__c.addError('您定义的常量不符合规定'); } }
}

完整代码:

 public class TestUsage {
public static final Decimal randomNumber = Decimal.valueOf(Math.random());//生成一个随机常量
public Integer sortNum;//List长度
public Decimal averge;//平均值
public Decimal sum; /*插入数据到Object customnerUsage*/
public void TestUsage(){
List<Decimal> songnameValue = getData();
sortNum=songnameValue.size();
system.debug('数组长度=================='+sortNum);
averge= (songnameValue[0]+songnameValue[1]+songnameValue[2]+songnameValue[sortNum-3]+songnameValue[sortNum-2]+songnameValue[sortNum-1])/6;
system.debug('平均值========================'+averge);
sum = randomNumber * averge;
system.debug('平均值乘以常量结果========================'+sum);
CustomerUsage__c customnerUsage = new CustomerUsage__c();
customnerUsage.UsageIndex__c=sum;
insert customnerUsage;
}
/*从Object SongName__c 获得数据,并将获取结果排序*/
public List<Decimal> getData(){
List<SongName__c> SongName=CreateData(); Map<Id, Decimal> SongNameMap = new Map<Id, Decimal>();
for (SongName__c sn: SongName ){
SongNameMap.put(sn.id, sn.usage__c);
} Set <Id> SongNameKey = new Set<Id>();
List<Decimal> songnameValue = new List<Decimal>();
SongNameKey = SongNameMap.keyset();
for(String key: SongNameKey){
songnameValue.add(SongNameMap.get(key));
}
system.debug('GET的数据是======================='+songnameValue);
Quicksort.sortStatic(songnameValue);
system.debug('排序结果======================='+songnameValue);
return songnameValue;
}
/*向表SongName__c插入101条数据*/
public List<SongName__c> CreateData(){
List<SongName__c> songName = new List<SongName__c>();
for(Integer i=0; i<101; i++){
SongName__c a = new SongName__c(Song__c = '歌曲' + i,Contact_email__c ='wicky@sina.com',password__c ='19920122', usage__c = i+100, Active__c = true);
songName.add(a);
} try{
insert songName;
}
catch(DmlException e){
System.debug('An unexpected error has occurred'+e.getMessage());
}
SongName = [Select usage__c FROM SongName__c Where CreatedDate>=2016-10-22T00:00:00+08:00
and CreatedDate<=2016-10-27T00:00:00+08:00 ]; system.debug('插入SongName__c的数据========================'+SongName);
return SongName; } }

  

 

APEX:对object中数据进行简单处理?的更多相关文章

  1. Java中的equals和==的区别以及几个常用的object中的方法简单的调试方法

    一.equals 1.equals:是Object类中的方法,只能判断引用类型 2.默认判断的是地址是否相等(判断两个参数是否是同一个对象),子类中往往重写该方法,用于判断内容(值)是否相等 二.== ...

  2. Hive数据导入——数据存储在Hadoop分布式文件系统中,往Hive表里面导入数据只是简单的将数据移动到表所在的目录中!

    转自:http://blog.csdn.net/lifuxiangcaohui/article/details/40588929 Hive是基于Hadoop分布式文件系统的,它的数据存储在Hadoop ...

  3. 第2/24周 页_SQL Server 中数据存储的基本单位

    上周通过探讨SQL Server如何执行一个查询奠定了基础.我也在那里提到页是8kb的缓存.今天我们对页进行进一步集中探讨,从性能调优角度挖掘出更多的细节. 页是SQL Server的基础,在SQL ...

  4. PHP5中PDO的简单使用

    PHP5中PDO的简单使用 标签: php数据库mysql扩展extensionexception 2012-05-06 10:27 27753人阅读 评论(0) 收藏 举报  分类: PHP(6)  ...

  5. iphone开发中数据持久化之——属性列表序列化(一)

    数据持久化是应用程序开发过程中的一个基本问题,对应用程序中的数据进行持久化存储,有多重不同的形式.本系列文章将介绍在iphone开发过程中数据持久化的三种主要形式,分别是属性列表序列号.对象归档化以及 ...

  6. iOS 项目中的NSNotification简单使用

    iOS中NSNotification的简单使用 好久没有写过博客了,总是遇到问题查一下,今天查的又是一个老问题,想了想,还是记录一下!今天在项目开发中遇到一个配置及时性处理的问题,想了想之后决定用通知 ...

  7. 第2周 页_SQL Server 中数据存储的基本单位

    原文:第2周 页_SQL Server 中数据存储的基本单位 上周通过探讨SQL Server如何执行一个查询奠定了基础.我也在那里提到页是8kb的缓存.今天我们对页进行进一步集中探讨,从性能调优角度 ...

  8. Object中的方法以及对象相等的判定

    看图说话 Object有以下几个方法 getClass() final类型,主要是用来获得运行时的类型 hashCode() 返回该对象的哈希码值,方法是为了提高哈希表(例如 java.util.Ha ...

  9. Java中数据类型转换&基本类型变量和对象型变量

    1.Java的数据类型分为三大类 布尔型,字符型和数值型 其中数值型又分为整型和浮点型 2.Java的变量类型 布尔型 boolean 字符型 char 整型    byte,short,int,lo ...

随机推荐

  1. Java MyBatis 插入数据库返回主键

    最近在搞一个电商系统中由于业务需求,需要在插入一条产品信息后返回产品Id,刚开始遇到一些坑,这里做下笔记,以防今后忘记. 类似下面这段代码一样获取插入后的主键 User user = new User ...

  2. mybatis_基础篇

    一.认识mybatis: MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改 ...

  3. 6.在MVC中使用泛型仓储模式和依赖注入实现增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...

  4. Android Retrofit 2.0 使用-补充篇

    推荐阅读,猛戳: 1.Android MVP 实例 2.Android Retrofit 2.0使用 3.RxJava 4.RxBus 5.Android MVP+Retrofit+RxJava实践小 ...

  5. Android之DOM解析XML

    一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...

  6. 在配有英特尔® Iris™ 显卡的系统上通过优化对 Just Cause 3 进行增强

    高端 PC 继续通过高性能显卡驱动桌面游戏. 一流的"梦想机器"基于第六代智能 英特尔® 酷睿™ 处理器i7-6700K等 CPU,通常与高端独立显卡配合使用以运行要求最严苛的游戏 ...

  7. 免费SSL证书 之Let’s Encrypt申请与部署(Windows Nginx)

    我着着皇帝的新衣,但是你看不见    有一颗愿意等待的心,说明你对未来充满希望.有一颗充满希望的心,那么等待又算什么.人就是在等待与希望中度过,我们永远要对未来充满信心! 读在最前面: 1.本文案例为 ...

  8. CodingLife主题更新

    收到反馈说CodingLife主题某些地方显示有问题,于是进行了更新,并且已提交.官方那边正在进行测试,我自己这边测完应该是没问题的,但不知道官方啥时候会进行更新,所以把CSS代码贴出来,有需要的可以 ...

  9. JavaScript的妙与乐(一)之 函数优化

    JavaScript的妙与乐系列文章主要是展示一些JavaScript上面比较好玩一点的特性和一些有用的技巧,里面很多内容都是我曾经在项目中使用过的一些内容(当然,未必所有技巧的使用频率都很高^_^) ...

  10. ASP.NET Web API 控制器创建过程(二)

    ASP.NET Web API 控制器创建过程(二) 前言 本来这篇随笔应该是在上周就该写出来发布的,由于身体跟不上节奏感冒发烧有心无力,这种天气感冒发烧生不如死,也真正的体会到了什么叫病来如山倒,病 ...