APEX:对object中数据进行简单处理?
在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中数据进行简单处理?的更多相关文章
- Java中的equals和==的区别以及几个常用的object中的方法简单的调试方法
一.equals 1.equals:是Object类中的方法,只能判断引用类型 2.默认判断的是地址是否相等(判断两个参数是否是同一个对象),子类中往往重写该方法,用于判断内容(值)是否相等 二.== ...
- Hive数据导入——数据存储在Hadoop分布式文件系统中,往Hive表里面导入数据只是简单的将数据移动到表所在的目录中!
转自:http://blog.csdn.net/lifuxiangcaohui/article/details/40588929 Hive是基于Hadoop分布式文件系统的,它的数据存储在Hadoop ...
- 第2/24周 页_SQL Server 中数据存储的基本单位
上周通过探讨SQL Server如何执行一个查询奠定了基础.我也在那里提到页是8kb的缓存.今天我们对页进行进一步集中探讨,从性能调优角度挖掘出更多的细节. 页是SQL Server的基础,在SQL ...
- PHP5中PDO的简单使用
PHP5中PDO的简单使用 标签: php数据库mysql扩展extensionexception 2012-05-06 10:27 27753人阅读 评论(0) 收藏 举报 分类: PHP(6) ...
- iphone开发中数据持久化之——属性列表序列化(一)
数据持久化是应用程序开发过程中的一个基本问题,对应用程序中的数据进行持久化存储,有多重不同的形式.本系列文章将介绍在iphone开发过程中数据持久化的三种主要形式,分别是属性列表序列号.对象归档化以及 ...
- iOS 项目中的NSNotification简单使用
iOS中NSNotification的简单使用 好久没有写过博客了,总是遇到问题查一下,今天查的又是一个老问题,想了想,还是记录一下!今天在项目开发中遇到一个配置及时性处理的问题,想了想之后决定用通知 ...
- 第2周 页_SQL Server 中数据存储的基本单位
原文:第2周 页_SQL Server 中数据存储的基本单位 上周通过探讨SQL Server如何执行一个查询奠定了基础.我也在那里提到页是8kb的缓存.今天我们对页进行进一步集中探讨,从性能调优角度 ...
- Object中的方法以及对象相等的判定
看图说话 Object有以下几个方法 getClass() final类型,主要是用来获得运行时的类型 hashCode() 返回该对象的哈希码值,方法是为了提高哈希表(例如 java.util.Ha ...
- Java中数据类型转换&基本类型变量和对象型变量
1.Java的数据类型分为三大类 布尔型,字符型和数值型 其中数值型又分为整型和浮点型 2.Java的变量类型 布尔型 boolean 字符型 char 整型 byte,short,int,lo ...
随机推荐
- JavaScript Date对象
本篇主要介绍 Date 日期和时间对象的操作. 目录 1. 介绍:阐述 Date 对象. 2. 构造函数:介绍 Date 对象的构造函数new Date()几种方式. 3. 实例方法:介绍 Date ...
- 【原】AFNetworking源码阅读(四)
[原]AFNetworking源码阅读(四) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇还遗留了很多问题,包括AFURLSessionManagerTaskDe ...
- Go结构体实现类似成员函数机制
Go语言结构体成员能否是函数,从而实现类似类的成员函数的机制呢?答案是肯定的. package main import "fmt" type stru struct { testf ...
- [原] KVM虚拟机网络闪断分析
背景 公司云平台的机器时常会发生网络闪断,通常在10s-100s之间. 异常情况 VM出现问题时,表现出来的情况是外部监控系统无法访问,猜测可能是由于系统假死,OVS链路问题等等.但是在出现网络问题的 ...
- 在centos7上安装ClamAV杀毒,并杀毒(centos随机英文10字母)成功
前言 上传文件的时候发现总是失败,查看top发现有个进程一直cpu占用80%以上,而且名称还是随机数.kill之后,一会儿又重新生成了.突然发现居然没有在服务端杀毒的经历.在此处补齐. 安装clama ...
- PHP设计模式(一)简单工厂模式 (Simple Factory For PHP)
最近天气变化无常,身为程序猿的寡人!~终究难耐天气的挑战,病倒了,果然,程序猿还需多保养自己的身体,有句话这么说:一生只有两件事能报复你:不够努力的辜负和过度消耗身体的后患.话不多说,开始吧. 一.什 ...
- React Native Android gradle下载慢问题解决
很多人会遇到 初次运行 react-native run android的时候 gradle下载极慢,甚至会失败的问题 如下图 实际上这个问题好解决的 首先 把对应版本的gradle下载到本地任意一个 ...
- Android开发学习—— shape标签的使用
参考这片文章http://www.cnblogs.com/armyfai/p/5912414.html
- 两个变量交换的四种方法(Java)
对于两种变量的交换,我发现四种方法,下面我用Java来演示一下. 1.利用第三个变量交换数值,简单的方法. (代码演示一下) class TestEV //创建一个类 { public static ...
- mono for android Json 上传文件
void button_Click(object sender, EventArgs e) { string Url = "上传地址,服务器端负责接收"; byte[] fbyte ...