Illegal assignment from SObject to ContactFetching String, Id from Map - Illegal Assignment Id to Field /...

Unexpected email from Yorkshire Bank

Why do Computer Science majors learn Calculus?

When and why did journal article titles become descriptive, rather than creatively allusive?

Will a top journal at least read my introduction?

Is it possible to dynamically set properties of an `Object` using Apex?

Upright [...] in italics quotation

How to delegate to implementing class

Normal subgroup of even order whose nontrivial elements form a single conjugacy class is abelian

Bayes Nash Equilibria in Battle of Sexes

Reverse the word in a string with the same order in javascript

Any examples of headwear for races with animal ears?

Illegal assignment from SObject to Contact

Corner spot where three faces meet

How does a swashbuckler fight with two weapons and safely dart away?

Phrase for the opposite of "foolproof"

Is thermodynamics only applicable to systems in equilibrium?

gnu parallel how to use with ffmpeg

Why does nature favour the Laplacian?

How can Republicans who favour free markets, consistently express anger when they don't like the outcome of that choice?

Binary Numbers Magic Trick

Will tsunami waves travel forever if there was no land?

What is the strongest case that can be made in favour of the UK regaining some control over fishing policy after Brexit?

Feels like I am getting dragged in office politics

What are the spoon bit of a spoon and fork bit of a fork called?



Illegal assignment from SObject to Contact


Fetching String, Id from Map - Illegal Assignment Id to Field / ObjectError: Compile Error: Illegal assignment from String to BooleanError: List has no rows for assignment to SObjectError on Test Class - System.QueryException: List has no rows for assignment to SObjectRemote action problemDML requires SObject or SObject list type error“Illegal assignment from List to List”Test Class Fail: Batch Class: System.QueryException: List has no rows for assignment to SObjectMapping to a user'List has no rows for assignment to SObject' Mystery






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ margin-bottom:0;
}







1















I am getting the following error:




Illegal assignment from SObject to Contact




I created a class called DynamicSObjectUpdater that I use to consolidate DML statements in my triggers. Basically you just call the class getSObject and it appends the SObject to a Map called sorToUpdate and then returns the SObject.



In one of my classes, I am calling the Class and its saying the following code is an illegal assignment from SObject to Contact.



Contact conToUpdate = sObjectUpdater.getSObject(con.Id);


I am not sure what I am missing here to make this work.



public with sharing class DyanmicSObjectUpdater {

Map<SObjectType, Map<Id, sObject>> sorToUpdate = new Map<SObjectType, Map<Id, sObject>>();

public SObject getSObject(ID sObjectID)
{
SObjectType sot = sObjectID.getSobjectType();

if(!sorToUpdate.containsKey(sot))
{
sorToUpdate.put(sot, new Map<Id, SObject>());
}

SObject targetSObject = sorToUpdate.get(sot).get(sObjectID);

if(targetSObject == null)
{
targetSObject = sObjectID.getSobjectType().newSobject(sObjectID);
sorToUpdate.get(sot).put(sObjectID, targetSObject);
}

return targetSObject;
}


public void updateSObjects()
{

List<SObject> sObjectsToUpdate = new List<SObject>();
if(sObjectsToUpdate.size() > 0)
{
for(SObjectType sorType: sorToUpdate.keySet())
{
sObjectsToUpdate.addAll(sorToUpdate.get(sorType).values());
}
}

if(sObjectsToUpdate.size()>0) update sObjectsToUpdate;
}
}









share|improve this question































    1















    I am getting the following error:




    Illegal assignment from SObject to Contact




    I created a class called DynamicSObjectUpdater that I use to consolidate DML statements in my triggers. Basically you just call the class getSObject and it appends the SObject to a Map called sorToUpdate and then returns the SObject.



    In one of my classes, I am calling the Class and its saying the following code is an illegal assignment from SObject to Contact.



    Contact conToUpdate = sObjectUpdater.getSObject(con.Id);


    I am not sure what I am missing here to make this work.



    public with sharing class DyanmicSObjectUpdater {

    Map<SObjectType, Map<Id, sObject>> sorToUpdate = new Map<SObjectType, Map<Id, sObject>>();

    public SObject getSObject(ID sObjectID)
    {
    SObjectType sot = sObjectID.getSobjectType();

    if(!sorToUpdate.containsKey(sot))
    {
    sorToUpdate.put(sot, new Map<Id, SObject>());
    }

    SObject targetSObject = sorToUpdate.get(sot).get(sObjectID);

    if(targetSObject == null)
    {
    targetSObject = sObjectID.getSobjectType().newSobject(sObjectID);
    sorToUpdate.get(sot).put(sObjectID, targetSObject);
    }

    return targetSObject;
    }


    public void updateSObjects()
    {

    List<SObject> sObjectsToUpdate = new List<SObject>();
    if(sObjectsToUpdate.size() > 0)
    {
    for(SObjectType sorType: sorToUpdate.keySet())
    {
    sObjectsToUpdate.addAll(sorToUpdate.get(sorType).values());
    }
    }

    if(sObjectsToUpdate.size()>0) update sObjectsToUpdate;
    }
    }









    share|improve this question



























      1












      1








      1








      I am getting the following error:




      Illegal assignment from SObject to Contact




      I created a class called DynamicSObjectUpdater that I use to consolidate DML statements in my triggers. Basically you just call the class getSObject and it appends the SObject to a Map called sorToUpdate and then returns the SObject.



      In one of my classes, I am calling the Class and its saying the following code is an illegal assignment from SObject to Contact.



      Contact conToUpdate = sObjectUpdater.getSObject(con.Id);


      I am not sure what I am missing here to make this work.



      public with sharing class DyanmicSObjectUpdater {

      Map<SObjectType, Map<Id, sObject>> sorToUpdate = new Map<SObjectType, Map<Id, sObject>>();

      public SObject getSObject(ID sObjectID)
      {
      SObjectType sot = sObjectID.getSobjectType();

      if(!sorToUpdate.containsKey(sot))
      {
      sorToUpdate.put(sot, new Map<Id, SObject>());
      }

      SObject targetSObject = sorToUpdate.get(sot).get(sObjectID);

      if(targetSObject == null)
      {
      targetSObject = sObjectID.getSobjectType().newSobject(sObjectID);
      sorToUpdate.get(sot).put(sObjectID, targetSObject);
      }

      return targetSObject;
      }


      public void updateSObjects()
      {

      List<SObject> sObjectsToUpdate = new List<SObject>();
      if(sObjectsToUpdate.size() > 0)
      {
      for(SObjectType sorType: sorToUpdate.keySet())
      {
      sObjectsToUpdate.addAll(sorToUpdate.get(sorType).values());
      }
      }

      if(sObjectsToUpdate.size()>0) update sObjectsToUpdate;
      }
      }









      share|improve this question
















      I am getting the following error:




      Illegal assignment from SObject to Contact




      I created a class called DynamicSObjectUpdater that I use to consolidate DML statements in my triggers. Basically you just call the class getSObject and it appends the SObject to a Map called sorToUpdate and then returns the SObject.



      In one of my classes, I am calling the Class and its saying the following code is an illegal assignment from SObject to Contact.



      Contact conToUpdate = sObjectUpdater.getSObject(con.Id);


      I am not sure what I am missing here to make this work.



      public with sharing class DyanmicSObjectUpdater {

      Map<SObjectType, Map<Id, sObject>> sorToUpdate = new Map<SObjectType, Map<Id, sObject>>();

      public SObject getSObject(ID sObjectID)
      {
      SObjectType sot = sObjectID.getSobjectType();

      if(!sorToUpdate.containsKey(sot))
      {
      sorToUpdate.put(sot, new Map<Id, SObject>());
      }

      SObject targetSObject = sorToUpdate.get(sot).get(sObjectID);

      if(targetSObject == null)
      {
      targetSObject = sObjectID.getSobjectType().newSobject(sObjectID);
      sorToUpdate.get(sot).put(sObjectID, targetSObject);
      }

      return targetSObject;
      }


      public void updateSObjects()
      {

      List<SObject> sObjectsToUpdate = new List<SObject>();
      if(sObjectsToUpdate.size() > 0)
      {
      for(SObjectType sorType: sorToUpdate.keySet())
      {
      sObjectsToUpdate.addAll(sorToUpdate.get(sorType).values());
      }
      }

      if(sObjectsToUpdate.size()>0) update sObjectsToUpdate;
      }
      }






      apex






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 1 hour ago









      Robs

      2,569743




      2,569743










      asked 1 hour ago









      Matthew MetrosMatthew Metros

      774




      774






















          2 Answers
          2






          active

          oldest

          votes


















          1














          You need to cast the return value.



          Contact conToUpdate = (Contact)sObjectUpdater.getSObject(con.Id);


          More generally, you cannot directly assign a value typed at compile time as a superclass (like sObject) to a variable typed as a subclass (Contact is a subclass of sObject). You can perform a cast to tell the compiler that the sObject instance you're getting back from getSObject() is actually a Contact; if at runtime this is not the case (i.e., you get back an Account or something else that isn't a Contact), you will receive an exception.



          You might find the implementation of the Unit of Work pattern in fflib interesting as you're building this type of generic/abstracted DML code.






          share|improve this answer
























          • Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

            – Matthew Metros
            15 mins ago













          • @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

            – David Reed
            2 mins ago



















          1














          You need to cast the result



          Contact conToUpdate = (Contact) sObjectUpdater.getSObject(con.Id);





          share|improve this answer
























            Your Answer








            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "459"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });














            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f260343%2fillegal-assignment-from-sobject-to-contact%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            2 Answers
            2






            active

            oldest

            votes








            2 Answers
            2






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            1














            You need to cast the return value.



            Contact conToUpdate = (Contact)sObjectUpdater.getSObject(con.Id);


            More generally, you cannot directly assign a value typed at compile time as a superclass (like sObject) to a variable typed as a subclass (Contact is a subclass of sObject). You can perform a cast to tell the compiler that the sObject instance you're getting back from getSObject() is actually a Contact; if at runtime this is not the case (i.e., you get back an Account or something else that isn't a Contact), you will receive an exception.



            You might find the implementation of the Unit of Work pattern in fflib interesting as you're building this type of generic/abstracted DML code.






            share|improve this answer
























            • Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

              – Matthew Metros
              15 mins ago













            • @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

              – David Reed
              2 mins ago
















            1














            You need to cast the return value.



            Contact conToUpdate = (Contact)sObjectUpdater.getSObject(con.Id);


            More generally, you cannot directly assign a value typed at compile time as a superclass (like sObject) to a variable typed as a subclass (Contact is a subclass of sObject). You can perform a cast to tell the compiler that the sObject instance you're getting back from getSObject() is actually a Contact; if at runtime this is not the case (i.e., you get back an Account or something else that isn't a Contact), you will receive an exception.



            You might find the implementation of the Unit of Work pattern in fflib interesting as you're building this type of generic/abstracted DML code.






            share|improve this answer
























            • Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

              – Matthew Metros
              15 mins ago













            • @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

              – David Reed
              2 mins ago














            1












            1








            1







            You need to cast the return value.



            Contact conToUpdate = (Contact)sObjectUpdater.getSObject(con.Id);


            More generally, you cannot directly assign a value typed at compile time as a superclass (like sObject) to a variable typed as a subclass (Contact is a subclass of sObject). You can perform a cast to tell the compiler that the sObject instance you're getting back from getSObject() is actually a Contact; if at runtime this is not the case (i.e., you get back an Account or something else that isn't a Contact), you will receive an exception.



            You might find the implementation of the Unit of Work pattern in fflib interesting as you're building this type of generic/abstracted DML code.






            share|improve this answer













            You need to cast the return value.



            Contact conToUpdate = (Contact)sObjectUpdater.getSObject(con.Id);


            More generally, you cannot directly assign a value typed at compile time as a superclass (like sObject) to a variable typed as a subclass (Contact is a subclass of sObject). You can perform a cast to tell the compiler that the sObject instance you're getting back from getSObject() is actually a Contact; if at runtime this is not the case (i.e., you get back an Account or something else that isn't a Contact), you will receive an exception.



            You might find the implementation of the Unit of Work pattern in fflib interesting as you're building this type of generic/abstracted DML code.







            share|improve this answer












            share|improve this answer



            share|improve this answer










            answered 1 hour ago









            David ReedDavid Reed

            40.5k82360




            40.5k82360













            • Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

              – Matthew Metros
              15 mins ago













            • @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

              – David Reed
              2 mins ago



















            • Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

              – Matthew Metros
              15 mins ago













            • @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

              – David Reed
              2 mins ago

















            Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

            – Matthew Metros
            15 mins ago







            Thank you for the insight on this. I am beginning to learn generic/abstracted coding patterns. Let me know if you have any resources that you can point me to that you found helpful when you were beginning to learn these topics.

            – Matthew Metros
            15 mins ago















            @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

            – David Reed
            2 mins ago





            @MatthewMetros That's a good question, and I don't have a great answer for you. Reading good code from major Salesforce open source projects is certainly one route.

            – David Reed
            2 mins ago













            1














            You need to cast the result



            Contact conToUpdate = (Contact) sObjectUpdater.getSObject(con.Id);





            share|improve this answer




























              1














              You need to cast the result



              Contact conToUpdate = (Contact) sObjectUpdater.getSObject(con.Id);





              share|improve this answer


























                1












                1








                1







                You need to cast the result



                Contact conToUpdate = (Contact) sObjectUpdater.getSObject(con.Id);





                share|improve this answer













                You need to cast the result



                Contact conToUpdate = (Contact) sObjectUpdater.getSObject(con.Id);






                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered 1 hour ago









                RobsRobs

                2,569743




                2,569743






























                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Salesforce Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f260343%2fillegal-assignment-from-sobject-to-contact%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Gersau Kjelder | Navigasjonsmeny46°59′0″N 8°31′0″E46°59′0″N...

                    Nässjö kommun Tettstader | Kjelder | NavigasjonsmenyeVIAFISNIGeoNamesMusicBrainz (area)

                    Kvitkval Innhaldsliste Taksonomi og utvikling | Utsjånad og levevis | Utbreiing | Åtferd |...