Apex和SOQL - 根据唯一字符串字段执行upsert
创始人
2024-11-10 04:30:02
0

在Apex中使用SOQL执行upsert操作,需要按照以下步骤进行操作:

  1. 首先,创建一个唯一字符串字段的目标对象。例如,假设我们要将数据插入到名为"Account"的对象中,并且有一个唯一字符串字段"ExternalId__c"。

  2. 创建一个包含要upsert的记录的列表。每个记录必须包含一个唯一字符串字段的值。

List accountsToUpsert = new List();
accountsToUpsert.add(new Account(ExternalId__c = 'ABC123', Name = 'Test Account 1'));
accountsToUpsert.add(new Account(ExternalId__c = 'DEF456', Name = 'Test Account 2'));
  1. 使用SOQL查询来查找已存在的记录。在查询中使用"IN"关键字,并将唯一字符串字段的值作为参数传递。
List existingAccounts = [SELECT Id, ExternalId__c FROM Account WHERE ExternalId__c IN :accountsToUpsert];
  1. 创建一个Map来存储已存在记录的唯一字符串字段值和对应的记录Id。这将帮助我们在upsert操作中更新现有记录。
Map existingAccountsMap = new Map();
for (Account acc : existingAccounts) {
    existingAccountsMap.put(acc.ExternalId__c, acc.Id);
}
  1. 创建一个新的列表来存储要插入和更新的记录。
List accountsToInsert = new List();
List accountsToUpdate = new List();

for (Account acc : accountsToUpsert) {
    if (existingAccountsMap.containsKey(acc.ExternalId__c)) {
        acc.Id = existingAccountsMap.get(acc.ExternalId__c);
        accountsToUpdate.add(acc);
    } else {
        accountsToInsert.add(acc);
    }
}
  1. 使用upsert关键字执行upsert操作。
upsert accountsToInsert ExternalId__c;
upsert accountsToUpdate ExternalId__c;

上述代码示例演示了如何使用SOQL查询和upsert操作根据唯一字符串字段执行upsert操作。请根据自己的需求进行相应的调整。

相关内容

热门资讯

第五分钟带你了解!广西优乐免费... 第五分钟带你了解!广西优乐免费辅助(辅助挂)科技通报外挂开挂辅助平台(一直真的有挂) 【无需打开直接...
发现一款"山西大唐辅... 发现一款"山西大唐辅助器"开挂(透视)辅助平台(一贯是真的有挂的)-哔哩哔哩;1、不需要AI权限,帮...
第十分钟带你了解!四川途游破解... 第十分钟带你了解!四川途游破解安装包(辅助挂)玩家必知教程外挂开挂辅助下载(一贯有挂);无需打开直接...
玩家必看秘籍"浙江正... 玩家必看秘籍"浙江正规游戏平台"开挂(透视)辅助下载(其实确实是有挂)-哔哩哔哩;小薇(透视辅助)致...
第9分钟带你了解!潮汕馆辅助(... 第9分钟带你了解!潮汕馆辅助(透视挂)揭秘一下外挂开挂辅助下载(其实真的有挂)《详细加薇136704...
一分钟了解"皮皮胡子... 一分钟了解"皮皮胡子辅助"开挂(透视)辅助神器(果然是真的有挂的)-哔哩哔哩,皮皮胡子辅助是用手机号...
2分钟带你了解!广东雀神挂机怎... 广东雀神挂机怎么样 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由: ...
分享实测"小程序牵手... 分享实测"小程序牵手跑得快辅助器"开挂(透视)辅助脚本(原来是真的有挂的)-哔哩哔哩;是一款可以让一...
一分钟带你了解!新道游辅助器透... 一分钟带你了解!新道游辅助器透视挂(辅助挂)每日必看外挂开挂辅助平台(果然有挂)新道游辅助器透视挂a...
最新技巧"丽水都来大... 最新技巧"丽水都来大菠萝脚本辅助"开挂(透视)辅助脚本(原来确实有挂的)-哔哩哔哩;丽水都来大菠萝脚...