0

我是在 APEX 中为 salesforce.com 编写代码的新手。我有一个包含 10 个字段的对象“UnProc”,它是“POPULATED”。我还有两个对象(“帐户和联系人”),每个对象有 5 个字段,必须填充这些对象。我必须使用批处理 apex 和调度程序编写 APEX 代码,以便我可以为“帐户”和“联系人”创建新记录,以记录“UnProc”中已经存在的记录。在使用 UnProc 记录填充 Account 和 Contact 字段之后。必须删除 UnProc 记录。

我已经阅读了 saleforce.com 上与批处理顶点和调度程序相关的文档,并且已经理解并为它们创建了类结构。我被困在的地方是记录检索、创作等。数据库是我的弱点,这就是我无法通过它的原因。伪代码或某些代码行可能很有用。

4

1 回答 1

2

通常使用 SOQL 从 Apex 代码中的数据库中检索记录。此处概述了基本语法。

从数据库中检索记录并作为 sObjects 发送回数据库,这些sObjects 本质上是字段的集合。SOQL 查询通常会返回一个 sObject 列表,如下所示:

list<UnProc__c> unProcs = [select accountField1__c, accountField2__c, ... contactField1__c, contactField2__c, ... contactField5__c from UnProc__c];

检索到这些记录后,您可以创建新的 Account 和 Contact 记录,只需创建 Account 和 Contact sObjects 的列表,从 UnProc 对象填充它们的字段,然后将它们提交到数据库,如下所示:

list<Account> accs = new list<Account>();
list<Contact> cons = new list<Contact>();
Account acc;
Contact con;
for(UnProc__c up : unProcs) {
    acc = new Account();
    con = new Contact();
    acc.field1 = up.accountField1;
    acc.field2 = up.accountField2;
    ...
    con.field1 = up.contactField1;
    con.field2 = up.contactField2;
    ...
    con.field5 = up.contactField5;
    accs.add(acc);
    cons.add(con);
}
database.insert(accs);
database.insert(cons);

在 Apex 中,您应该在记录集合中检索并提交到数据库,而不是单独提交,因为在单个执行上下文中可以运行的查询和提交数量是有限的。

于 2012-05-31T14:04:52.170 回答