Improve OR inside INNER JOIN





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








2

















I have this query. this is the second query. the first one was using the left/or outside the subquery, and the query plan was horrible.( Edited the question with the full sintax ):



https://www.brentozar.com/pastetheplan/?id=HJEioh56N



I have a nested loop (inner join) with 97% in the query plan.



I'm sure the problem is the OR inside the second join because I changed something here and there and I could get rid of them but I would like to be sure what would be the best way to deal with data like these. also all those tables has millions of rows.



Table Definition:



CREATE TABLE [DBO].[TABLE1](
[F1] [int] NOT NULL,
[F1] [varchar](16) NOT NULL,
[F3] [money] NOT NULL,
[F4] [money] NOT NULL,


I know created this index:



CREATE NONCLUSTERED INDEX IX_TB1 ON DBO.TABLE1
(
F1,
F2)



That index seek is now 14%, but got a HASH MATCH with 82% cost.










share|improve this question



































    2

















    I have this query. this is the second query. the first one was using the left/or outside the subquery, and the query plan was horrible.( Edited the question with the full sintax ):



    https://www.brentozar.com/pastetheplan/?id=HJEioh56N



    I have a nested loop (inner join) with 97% in the query plan.



    I'm sure the problem is the OR inside the second join because I changed something here and there and I could get rid of them but I would like to be sure what would be the best way to deal with data like these. also all those tables has millions of rows.



    Table Definition:



    CREATE TABLE [DBO].[TABLE1](
    [F1] [int] NOT NULL,
    [F1] [varchar](16) NOT NULL,
    [F3] [money] NOT NULL,
    [F4] [money] NOT NULL,


    I know created this index:



    CREATE NONCLUSTERED INDEX IX_TB1 ON DBO.TABLE1
    (
    F1,
    F2)



    That index seek is now 14%, but got a HASH MATCH with 82% cost.










    share|improve this question































      2












      2








      2


      1






      I have this query. this is the second query. the first one was using the left/or outside the subquery, and the query plan was horrible.( Edited the question with the full sintax ):



      https://www.brentozar.com/pastetheplan/?id=HJEioh56N



      I have a nested loop (inner join) with 97% in the query plan.



      I'm sure the problem is the OR inside the second join because I changed something here and there and I could get rid of them but I would like to be sure what would be the best way to deal with data like these. also all those tables has millions of rows.



      Table Definition:



      CREATE TABLE [DBO].[TABLE1](
      [F1] [int] NOT NULL,
      [F1] [varchar](16) NOT NULL,
      [F3] [money] NOT NULL,
      [F4] [money] NOT NULL,


      I know created this index:



      CREATE NONCLUSTERED INDEX IX_TB1 ON DBO.TABLE1
      (
      F1,
      F2)



      That index seek is now 14%, but got a HASH MATCH with 82% cost.










      share|improve this question

















      I have this query. this is the second query. the first one was using the left/or outside the subquery, and the query plan was horrible.( Edited the question with the full sintax ):



      https://www.brentozar.com/pastetheplan/?id=HJEioh56N



      I have a nested loop (inner join) with 97% in the query plan.



      I'm sure the problem is the OR inside the second join because I changed something here and there and I could get rid of them but I would like to be sure what would be the best way to deal with data like these. also all those tables has millions of rows.



      Table Definition:



      CREATE TABLE [DBO].[TABLE1](
      [F1] [int] NOT NULL,
      [F1] [varchar](16) NOT NULL,
      [F3] [money] NOT NULL,
      [F4] [money] NOT NULL,


      I know created this index:



      CREATE NONCLUSTERED INDEX IX_TB1 ON DBO.TABLE1
      (
      F1,
      F2)



      That index seek is now 14%, but got a HASH MATCH with 82% cost.







      sql-server sql-server-2008-r2 performance






      share|improve this question
















      share|improve this question













      share|improve this question




      share|improve this question








      edited Jun 14 at 16:39







      Racer SQL

















      asked May 28 at 13:06









      Racer SQLRacer SQL

      3,5315 gold badges31 silver badges75 bronze badges




      3,5315 gold badges31 silver badges75 bronze badges

























          1 Answer
          1






          active

          oldest

          votes


















          5


















          A common query rewrite that helps with OR predicates looks like this:



          SELECT tTitulo.CdContaCartao,
          tTitulo.CdStatus,
          MAX(DiariaMaxima)
          INTO #DiariaMaxima
          FROM Sistema.Titulo AS tTitulo
          CROSS APPLY
          (
          SELECT MAX(DiariaMaxima)
          FROM (
          SELECT tTIPM.DtDiaria
          FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
          INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
          ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
          WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao

          UNION ALL

          SELECT tTIPM.DtDiaria
          FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
          INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
          ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
          WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao_Visa
          ) AS x (DiariaMaxima)
          ) AS DiariaMaxima (DiariaMaxima)


          Apply is not always the best method for this, though I've often had success with it over using a regular derived JOIN.



          Some background on similar problems here:




          • Analysing A Query Plan

          • How to Optimise Query






          share|improve this answer




























            Your Answer








            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "182"
            };
            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/4.0/"u003ecc by-sa 4.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%2fdba.stackexchange.com%2fquestions%2f239210%2fimprove-or-inside-inner-join%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown


























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            5


















            A common query rewrite that helps with OR predicates looks like this:



            SELECT tTitulo.CdContaCartao,
            tTitulo.CdStatus,
            MAX(DiariaMaxima)
            INTO #DiariaMaxima
            FROM Sistema.Titulo AS tTitulo
            CROSS APPLY
            (
            SELECT MAX(DiariaMaxima)
            FROM (
            SELECT tTIPM.DtDiaria
            FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
            INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
            ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
            WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao

            UNION ALL

            SELECT tTIPM.DtDiaria
            FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
            INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
            ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
            WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao_Visa
            ) AS x (DiariaMaxima)
            ) AS DiariaMaxima (DiariaMaxima)


            Apply is not always the best method for this, though I've often had success with it over using a regular derived JOIN.



            Some background on similar problems here:




            • Analysing A Query Plan

            • How to Optimise Query






            share|improve this answer































              5


















              A common query rewrite that helps with OR predicates looks like this:



              SELECT tTitulo.CdContaCartao,
              tTitulo.CdStatus,
              MAX(DiariaMaxima)
              INTO #DiariaMaxima
              FROM Sistema.Titulo AS tTitulo
              CROSS APPLY
              (
              SELECT MAX(DiariaMaxima)
              FROM (
              SELECT tTIPM.DtDiaria
              FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
              INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
              ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
              WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao

              UNION ALL

              SELECT tTIPM.DtDiaria
              FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
              INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
              ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
              WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao_Visa
              ) AS x (DiariaMaxima)
              ) AS DiariaMaxima (DiariaMaxima)


              Apply is not always the best method for this, though I've often had success with it over using a regular derived JOIN.



              Some background on similar problems here:




              • Analysing A Query Plan

              • How to Optimise Query






              share|improve this answer





























                5














                5










                5









                A common query rewrite that helps with OR predicates looks like this:



                SELECT tTitulo.CdContaCartao,
                tTitulo.CdStatus,
                MAX(DiariaMaxima)
                INTO #DiariaMaxima
                FROM Sistema.Titulo AS tTitulo
                CROSS APPLY
                (
                SELECT MAX(DiariaMaxima)
                FROM (
                SELECT tTIPM.DtDiaria
                FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
                INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
                ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
                WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao

                UNION ALL

                SELECT tTIPM.DtDiaria
                FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
                INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
                ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
                WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao_Visa
                ) AS x (DiariaMaxima)
                ) AS DiariaMaxima (DiariaMaxima)


                Apply is not always the best method for this, though I've often had success with it over using a regular derived JOIN.



                Some background on similar problems here:




                • Analysing A Query Plan

                • How to Optimise Query






                share|improve this answer














                A common query rewrite that helps with OR predicates looks like this:



                SELECT tTitulo.CdContaCartao,
                tTitulo.CdStatus,
                MAX(DiariaMaxima)
                INTO #DiariaMaxima
                FROM Sistema.Titulo AS tTitulo
                CROSS APPLY
                (
                SELECT MAX(DiariaMaxima)
                FROM (
                SELECT tTIPM.DtDiaria
                FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
                INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
                ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
                WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao

                UNION ALL

                SELECT tTIPM.DtDiaria
                FROM Sistema.TaxaIndice_PagamentoMensal_ContaCartao AS tTIPM_Cartao
                INNER JOIN Sistema.TaxaIndice_PagamentoMensal AS tTIPM
                ON tTIPM.CdTaxaIndice_PagamentoMensal = tTIPM_Cartao.CdTaxaIndice_PagamentoMensal
                WHERE tTIPM_Cartao.CdContaCartao = tTitulo.CdContaCartao_Visa
                ) AS x (DiariaMaxima)
                ) AS DiariaMaxima (DiariaMaxima)


                Apply is not always the best method for this, though I've often had success with it over using a regular derived JOIN.



                Some background on similar problems here:




                • Analysing A Query Plan

                • How to Optimise Query







                share|improve this answer













                share|improve this answer




                share|improve this answer










                answered May 28 at 15:02









                Erik DarlingErik Darling

                28k13 gold badges86 silver badges143 bronze badges




                28k13 gold badges86 silver badges143 bronze badges


































                    draft saved

                    draft discarded



















































                    Thanks for contributing an answer to Database Administrators 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%2fdba.stackexchange.com%2fquestions%2f239210%2fimprove-or-inside-inner-join%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

                    Bruad Bilen | Luke uk diar | NawigatsjuunCommonskategorii: BruadCommonskategorii: RunstükenWikiquote: Bruad

                    Færeyskur hestur Heimild | Tengill | Tilvísanir | LeiðsagnarvalRossið - síða um færeyska hrossið á færeyskuGott ár hjá færeyska hestinum

                    He _____ here since 1970 . Answer needed [closed]What does “since he was so high” mean?Meaning of “catch birds for”?How do I ensure “since” takes the meaning I want?“Who cares here” meaningWhat does “right round toward” mean?the time tense (had now been detected)What does the phrase “ring around the roses” mean here?Correct usage of “visited upon”Meaning of “foiled rail sabotage bid”It was the third time I had gone to Rome or It is the third time I had been to Rome