编译错误:第33行第69列的通用SObject不允许使用字段表达式

时间:2015-09-29 06:27:16

标签: salesforce salesforce-chatter

我正在尝试编写一个适用于多种不同对象类型的通用控制器,但是当我尝试从这些对象访问自定义字段时,我收到以下错误:

  

编译错误:第33行第69列的通用SObject不允许使用字段表达式

这是我的通用控制器代码:

public with sharing class PhotoUploadController {

    public Attachment objAttach{get;set;}
    public sObject sobj{get;set;}
    public string ObjectName {get;set;}
    public Decimal Height{get;set;}
    public Decimal Width {get;set;}
    Public List<Attachment> lstAttachment {get;set;}

     public String setObjectType(sObject newObj)
      {
        this.ObjectName = newObj.getSObjectType().getDescribe().getName();
        return(this.ObjectName );
       }

    public String getObjectType() 
    {
          return(this.ObjectName);  
     }

   public PhotoUploadController (ApexPages.StandardController controller)
     {

        objAttach=new Attachment();
        lstAttachment= new List<Attachment>();
        sobj = controller.getRecord();
        if(sobj.id!=null){
           sobj = Database.query('select id,name,Image_Attachment_ID__c from ObjectName where id=:sobj.id');  
        } 

         if(sobj.Image_Attachment_ID__c!=null){

            lstattachment=[SELECT id,body from Attachment where Id=:sobj.Image_Attachment_ID__c limit 1];
            if(lstattachment.size()>0)
            {
                objAttach=lstattachment[0];
            }
        }         
    }

    public pageReference savePhoto(){  
     sobj.HeightOfPhoto__c=Height;
     sobj.WidthOfPhoto__c=Width;

        try {
            if (!Schema.sObjectType.sobjectName.isUpdateable())
                {
                  return null;
                }
            String contentType;

            if(objAttach.ContentType !=null){
               contentType=objAttach.ContentType;
            }

            if(contentType !=null && (contentType == 'image/jpeg' || contentType == 'image/CR2' || contentType== 'image/jpg' || contentType== 'image/png' || contentType== 'image/bmp' || contentType== 'image/gif')){            
            //objAttach.body=body;
            //objAttach.name=name;
            if(objAttach.body!=null && objAttach.name!=null && sobj.id !=null){
                 If(objAttach.Id==null)
                     objAttach.parentId=sobj.id;
                 if(!Schema.sObjectType.Attachment.isUpdateable()){
                  return null;
                  }

                 try{
                        upsert objAttach;
                        sobj.Image_URL__c=URL.getSalesforceBaseUrl().toExternalForm()+'/servlet/servlet.FileDownload?file='+objAttach.id;
                        sobj.Image_Attachment_ID__c= objAttach.id;
                        objAttach =null;
                        if (!Schema.sObjectType.ObjectName.isUpdateable()){
                          return null;
                        }
                       upsert sobj;
                   }
                   catch (DMLException e) {
                           if(e.getMessage().contains('STORAGE_LIMIT_EXCEEDED')){
                              ApexPages.addMessage(new ApexPages.message(ApexPages.severity.ERROR,'Your orgnization Storage Limit has been exceeded, Please contact your Administrator.'));
                           }else{
                             ApexPages.addMessage(new ApexPages.message(ApexPages.severity.ERROR,'Error uploading attachment'));
                           }
                           return null;
                    }finally {
                          objAttach = new Attachment();
                    }    
            }

         }
         else{
              objAttach = new Attachment();
              ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.ERROR,'Please, Upload image file with extension .JPG .JPEG .BMP .PNG or .GIF'));
              return null;
         }
        }
        catch(Exception e) {            
             return null;
        }
        return new pagereference('/'+sobj.id);    
    }

}

有人可以更详细地解释此错误消息吗?如何从通用SObject类型访问我需要的字段?

1 个答案:

答案 0 :(得分:0)

您的代码中存在几个问题,但报告错误消息的原因是此代码段:

sobj.Image_Attachment_ID__c

您没有指定您期望的SObject类型,因此无法知道:

  1. 如果内存中的SObject甚至 那个字段
  2. 它是什么类型的字段
  3. 该字段属于哪个元数据(如果该字段是一个选项列表,您可能有几个具有相同字段名称但具有不同选项列表选项的SObject等)
  4. 在这种情况下,get(fieldName)函数可能对您有用。如果SObject没有该字段,您最终可能会遇到异常(您可以捕获),并且您可以将值转换为正确的数据类型(因为它只会返回一个对象),这可能是如果值是日期时间并且您尝试将其强制转换为Id等,则抛出一个转换错误

    我发现了另一个问题:

    [SELECT id,body from Attachment where Id=:sobj.Image_Attachment_ID__c limit 1]永远不会返回值。我认为你的意思是ParentId=:sobj.Image_Attachment_ID__c