Salesforce的第一个错误:INVALID_CROSS_REFERENCE_KEY,实体不可用

问题描述

当我尝试运行测试类时,出现以下错误。

System.DmlException: Update failed. First exception on row 0 with id 8023B000000ekyaQAA; first error: INVALID_CROSS_REFERENCE_KEY,Entity not available: [PricebookEntryId]

也在调试日志的堆栈跟踪中,我收到以下消息

Class.OBOrderLineItemCreate.updateObjectMethod: line 367,column 1

我已经创建了产品并参考了标准价格手册。并创建了Pricebookentry,Order和Order订单项。我不确定为什么会收到此错误。谁能帮我这个忙,让我知道我做错了吗?预先感谢。

我的测试课程代码如下

Product2 prod = new Product2();
        prod.Name                = 'Inb Enterprise';
        prod.Description         = 'Annual subscription,80 topics,40,000 company locations';
        prod.productCode         = 'ABC';
        prod.Service_Type__c     = 'Inb';
        prod.OB_Sub_Type_Name__c = 'Inb';
        prod.isActive            = true;
        insert prod;

        Pricebook2 standardPricebook = new Pricebook2(
            Id = Test.getStandardPricebookId(),IsActive = true
        );

        update standardPricebook;

        standardPricebook = [SELECT Id,IsStandard FROM Pricebook2 WHERE Id = :standardPricebook.Id];


        //Id pricebookId = Test.getStandardPricebookId();
        //Test.startTest();
        PricebookEntry standardPrice = new PricebookEntry();
        standardPrice.Pricebook2Id = standardPricebook.Id;
        standardPrice.Product2Id = prod.Id;
        standardPrice.UnitPrice = 10000;
        standardPrice.IsActive = true;
        insert standardPrice;


        Order ord                       = new Order();
        ord.Name                        = 'Test Order';
        ord.AccountId                   = acc.Id;
        ord.Pricebook2Id                = standardPricebook.Id;
        ord.Customer_Success_Manager__c = am.Id;
        ord.Agency_Name__c              = agc.Id;
        ord.OpportunityId               = opp.Id;
        ord.Purchase_Order__c           = '783983';
        ord.EffectiveDate               = Date.today();
        ord.Status                      = 'Draft';
        ord.OBSyncStatus__c             = 'Inactive';
        ord.End_Date__c                 = Date.today();
        insert ord;

        OrderItem oli                = new OrderItem();
        oli.OrderId                  = ord.Id;
        oli.PricebookEntryId         = standardPrice.Id;
        oli.Quantity                 = 5;
        oli.UnitPrice                = 35;
        oli.OBSyncStatus__c          = 'Inactive';
        oli.Line_Item_Start_Date__c  = Date.Today();
        oli.Line_Item_End_Date__c    = Date.Today();
        oli.Bonus_Units__c           = 25;
        oli.Geography__c             = 'US';
        oli.Unique_Line_Item_Name__c = 'Inb Order';
        insert oli;

解决方法

您不需要实例化Pricebook2对象的代码。删除该代码,然后使用下面的代码。

standardPrice.Pricebook2Id = Test.getStandardPricebookId(). 

对ord.Pricebook2Id也执行相同操作。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...