In after trigger, which is a better practice: SOQL or utilise Trigger.New for further update?

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;







up vote
3
down vote

favorite












In after triggers, if I need to further update the context records, I usually use a SOQL query to grab the records from the database, something like:



List<CPQ_Data_Import__c> relatedCdiRecords = [Select Id, Json_PayLoad__c,
Completed__c,
External_Id_Field__c,
SObject_Type__c,
Response_Text__c,
Success__c
From CPQ_Data_Import__c
Where Id in :Trigger.New];


Now this new list is not read-only.



However, my client prefer to utilise Trigger.New more in this case, I am fine to write the code in this manner, something like:



 for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

CPQ_Data_Import__c cdiNew = cdi.clone();
cdiNew.Id = cdi.Id;
relatedCdiRecords.add(cdiNew);



Both of the above approaches will work. However, the second approach is still a bit strange to me. They made a fair point that if we add more and more fields into the SObject then we don't need to alter the SOQL query again and again (which I would argue because if we need to alter the SOQL query, we will need to adjust trigger code anyway). However, I don't see an obvious issue with the second approach aside from execution efficiency - which is of the least concern.



Any suggestions on which one is a better approach?







share|improve this question


























    up vote
    3
    down vote

    favorite












    In after triggers, if I need to further update the context records, I usually use a SOQL query to grab the records from the database, something like:



    List<CPQ_Data_Import__c> relatedCdiRecords = [Select Id, Json_PayLoad__c,
    Completed__c,
    External_Id_Field__c,
    SObject_Type__c,
    Response_Text__c,
    Success__c
    From CPQ_Data_Import__c
    Where Id in :Trigger.New];


    Now this new list is not read-only.



    However, my client prefer to utilise Trigger.New more in this case, I am fine to write the code in this manner, something like:



     for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

    CPQ_Data_Import__c cdiNew = cdi.clone();
    cdiNew.Id = cdi.Id;
    relatedCdiRecords.add(cdiNew);



    Both of the above approaches will work. However, the second approach is still a bit strange to me. They made a fair point that if we add more and more fields into the SObject then we don't need to alter the SOQL query again and again (which I would argue because if we need to alter the SOQL query, we will need to adjust trigger code anyway). However, I don't see an obvious issue with the second approach aside from execution efficiency - which is of the least concern.



    Any suggestions on which one is a better approach?







    share|improve this question






















      up vote
      3
      down vote

      favorite









      up vote
      3
      down vote

      favorite











      In after triggers, if I need to further update the context records, I usually use a SOQL query to grab the records from the database, something like:



      List<CPQ_Data_Import__c> relatedCdiRecords = [Select Id, Json_PayLoad__c,
      Completed__c,
      External_Id_Field__c,
      SObject_Type__c,
      Response_Text__c,
      Success__c
      From CPQ_Data_Import__c
      Where Id in :Trigger.New];


      Now this new list is not read-only.



      However, my client prefer to utilise Trigger.New more in this case, I am fine to write the code in this manner, something like:



       for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

      CPQ_Data_Import__c cdiNew = cdi.clone();
      cdiNew.Id = cdi.Id;
      relatedCdiRecords.add(cdiNew);



      Both of the above approaches will work. However, the second approach is still a bit strange to me. They made a fair point that if we add more and more fields into the SObject then we don't need to alter the SOQL query again and again (which I would argue because if we need to alter the SOQL query, we will need to adjust trigger code anyway). However, I don't see an obvious issue with the second approach aside from execution efficiency - which is of the least concern.



      Any suggestions on which one is a better approach?







      share|improve this question












      In after triggers, if I need to further update the context records, I usually use a SOQL query to grab the records from the database, something like:



      List<CPQ_Data_Import__c> relatedCdiRecords = [Select Id, Json_PayLoad__c,
      Completed__c,
      External_Id_Field__c,
      SObject_Type__c,
      Response_Text__c,
      Success__c
      From CPQ_Data_Import__c
      Where Id in :Trigger.New];


      Now this new list is not read-only.



      However, my client prefer to utilise Trigger.New more in this case, I am fine to write the code in this manner, something like:



       for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

      CPQ_Data_Import__c cdiNew = cdi.clone();
      cdiNew.Id = cdi.Id;
      relatedCdiRecords.add(cdiNew);



      Both of the above approaches will work. However, the second approach is still a bit strange to me. They made a fair point that if we add more and more fields into the SObject then we don't need to alter the SOQL query again and again (which I would argue because if we need to alter the SOQL query, we will need to adjust trigger code anyway). However, I don't see an obvious issue with the second approach aside from execution efficiency - which is of the least concern.



      Any suggestions on which one is a better approach?









      share|improve this question











      share|improve this question




      share|improve this question










      asked Aug 23 at 23:56









      Lance Shi

      7,19522568




      7,19522568




















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          6
          down vote



          accepted










          You should avoid using SOQLs arbitrarily. They are a very limited resource and the first governor limit you're most likely to hit in any large system. The second version is better of the two choices. However, an even better choice is option 3: copy only the values you need to copy. That looks like this:



          for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

          relatedCdiRecords.add(new CPQ_Data_Import__c(id=cdi.Id,...));



          This pattern preserves the most heap space, CPU time, and SOQL limits.



          While you're right that either pattern does work, and execution efficiency only matters up to a point, I would argue that developers should learn to get in the habit of writing efficient code.



          I've seen projects that were pushing right up against the limit (say 98 of 100 SOQL) that I was able to optimize down to 46 SOQL, for example. Compromising optimization in little ways like this can add up to severely compromised performance in the end.



          While most of the CPU-saving optimizations are typically not necessary--the main exception to that is using Map over nested for-loops--SOQL, DML, and SOSL optimizations are almost always necessary for future stability. You shouldn't be tempted to use a SOQL query just to construct a list of records you already have ID values for and all the data for. Use SOQL strictly for obtaining row locks, if necessary, and retrieving data you don't already have access to.






          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',
            convertImagesToLinks: false,
            noModals: false,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            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%2f229983%2fin-after-trigger-which-is-a-better-practice-soql-or-utilise-trigger-new-for-fu%23new-answer', 'question_page');

            );

            Post as a guest






























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            6
            down vote



            accepted










            You should avoid using SOQLs arbitrarily. They are a very limited resource and the first governor limit you're most likely to hit in any large system. The second version is better of the two choices. However, an even better choice is option 3: copy only the values you need to copy. That looks like this:



            for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

            relatedCdiRecords.add(new CPQ_Data_Import__c(id=cdi.Id,...));



            This pattern preserves the most heap space, CPU time, and SOQL limits.



            While you're right that either pattern does work, and execution efficiency only matters up to a point, I would argue that developers should learn to get in the habit of writing efficient code.



            I've seen projects that were pushing right up against the limit (say 98 of 100 SOQL) that I was able to optimize down to 46 SOQL, for example. Compromising optimization in little ways like this can add up to severely compromised performance in the end.



            While most of the CPU-saving optimizations are typically not necessary--the main exception to that is using Map over nested for-loops--SOQL, DML, and SOSL optimizations are almost always necessary for future stability. You shouldn't be tempted to use a SOQL query just to construct a list of records you already have ID values for and all the data for. Use SOQL strictly for obtaining row locks, if necessary, and retrieving data you don't already have access to.






            share|improve this answer
























              up vote
              6
              down vote



              accepted










              You should avoid using SOQLs arbitrarily. They are a very limited resource and the first governor limit you're most likely to hit in any large system. The second version is better of the two choices. However, an even better choice is option 3: copy only the values you need to copy. That looks like this:



              for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

              relatedCdiRecords.add(new CPQ_Data_Import__c(id=cdi.Id,...));



              This pattern preserves the most heap space, CPU time, and SOQL limits.



              While you're right that either pattern does work, and execution efficiency only matters up to a point, I would argue that developers should learn to get in the habit of writing efficient code.



              I've seen projects that were pushing right up against the limit (say 98 of 100 SOQL) that I was able to optimize down to 46 SOQL, for example. Compromising optimization in little ways like this can add up to severely compromised performance in the end.



              While most of the CPU-saving optimizations are typically not necessary--the main exception to that is using Map over nested for-loops--SOQL, DML, and SOSL optimizations are almost always necessary for future stability. You shouldn't be tempted to use a SOQL query just to construct a list of records you already have ID values for and all the data for. Use SOQL strictly for obtaining row locks, if necessary, and retrieving data you don't already have access to.






              share|improve this answer






















                up vote
                6
                down vote



                accepted







                up vote
                6
                down vote



                accepted






                You should avoid using SOQLs arbitrarily. They are a very limited resource and the first governor limit you're most likely to hit in any large system. The second version is better of the two choices. However, an even better choice is option 3: copy only the values you need to copy. That looks like this:



                for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

                relatedCdiRecords.add(new CPQ_Data_Import__c(id=cdi.Id,...));



                This pattern preserves the most heap space, CPU time, and SOQL limits.



                While you're right that either pattern does work, and execution efficiency only matters up to a point, I would argue that developers should learn to get in the habit of writing efficient code.



                I've seen projects that were pushing right up against the limit (say 98 of 100 SOQL) that I was able to optimize down to 46 SOQL, for example. Compromising optimization in little ways like this can add up to severely compromised performance in the end.



                While most of the CPU-saving optimizations are typically not necessary--the main exception to that is using Map over nested for-loops--SOQL, DML, and SOSL optimizations are almost always necessary for future stability. You shouldn't be tempted to use a SOQL query just to construct a list of records you already have ID values for and all the data for. Use SOQL strictly for obtaining row locks, if necessary, and retrieving data you don't already have access to.






                share|improve this answer












                You should avoid using SOQLs arbitrarily. They are a very limited resource and the first governor limit you're most likely to hit in any large system. The second version is better of the two choices. However, an even better choice is option 3: copy only the values you need to copy. That looks like this:



                for(CPQ_Data_Import__c cdi: (List<CPQ_Data_Import__c>)Trigger.New) 

                relatedCdiRecords.add(new CPQ_Data_Import__c(id=cdi.Id,...));



                This pattern preserves the most heap space, CPU time, and SOQL limits.



                While you're right that either pattern does work, and execution efficiency only matters up to a point, I would argue that developers should learn to get in the habit of writing efficient code.



                I've seen projects that were pushing right up against the limit (say 98 of 100 SOQL) that I was able to optimize down to 46 SOQL, for example. Compromising optimization in little ways like this can add up to severely compromised performance in the end.



                While most of the CPU-saving optimizations are typically not necessary--the main exception to that is using Map over nested for-loops--SOQL, DML, and SOSL optimizations are almost always necessary for future stability. You shouldn't be tempted to use a SOQL query just to construct a list of records you already have ID values for and all the data for. Use SOQL strictly for obtaining row locks, if necessary, and retrieving data you don't already have access to.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Aug 24 at 0:27









                sfdcfox

                225k10170384




                225k10170384



























                     

                    draft saved


                    draft discarded















































                     


                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f229983%2fin-after-trigger-which-is-a-better-practice-soql-or-utilise-trigger-new-for-fu%23new-answer', 'question_page');

                    );

                    Post as a guest













































































                    這個網誌中的熱門文章

                    How to combine Bézier curves to a surface?

                    Mutual Information Always Non-negative

                    Why am i infinitely getting the same tweet with the Twitter Search API?