Improve OR inside INNER JOINHow to Optimise QueryAnalysing A Query PlanStream Aggregate for Sort?How to improve the execution plan to speed up the queryRow estimates always too lowSpeeding up COUNT(*) with multiple equality, in and join conditionsSQL Server chooses Nested Loop join with dimensional table and make seek for each rowSpecify build and probe tables to hash join?Strange query plan when using OR in JOIN clause - Constant scan for every row in tablewhy is this left join faster than an inner join?SQL Server expensive nested loops join and lazy table spoolForce using an Index in Inner Join SELECT

Why is it bad to use your whole foot in rock climbing

Purpose of cylindrical attachments on Power Transmission towers

Am I allowed to determine tenets of my contract as a warlock?

How to soundproof the Wood Shop?

What's the difference between DHCP and NAT? Are they mutually exclusive?

Is there a frequency comparator device?

In The Incredibles 2, why does Screenslaver's name use a pun on something that doesn't exist in the 1950s pastiche?

Can I attach a DC blower to intake manifold of my 150CC Yamaha FZS FI engine?

Which are the methodologies for interpreting Vedas?

Can you open the door or die? v2

In American Politics, why is the Justice Department under the President?

Is it true that "only photographers care about noise"?

Print "N NE E SE S SW W NW"

If absolute velocity does not exist, how can we say a rocket accelerates in empty space?

A team managed by my peer is close to melting down

Placement of positioning lights on A320 winglets

Why would a home insurer offer a discount based on credit score?

What is the language spoken in Babylon?

Nth term of Van Eck Sequence

Why is my Taiyaki (Cake that looks like a fish) too hard and dry?

My mom's return ticket is 3 days after I-94 expires

When editor does not respond to the request for withdrawal

What does BREAD stand for while drafting?

How can calculate the turn-off time of an LDO?



Improve OR inside INNER JOIN


How to Optimise QueryAnalysing A Query PlanStream Aggregate for Sort?How to improve the execution plan to speed up the queryRow estimates always too lowSpeeding up COUNT(*) with multiple equality, in and join conditionsSQL Server chooses Nested Loop join with dimensional table and make seek for each rowSpecify build and probe tables to hash join?Strange query plan when using OR in JOIN clause - Constant scan for every row in tablewhy is this left join faster than an inner join?SQL Server expensive nested loops join and lazy table spoolForce using an Index in Inner Join SELECT






.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,


Im sure the problem is here:
enter image description here
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,


    Im sure the problem is here:
    enter image description here
    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,


      Im sure the problem is here:
      enter image description here
      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,


      Im sure the problem is here:
      enter image description here
      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 May 28 at 14:57









      Erik Darling

      24.1k1375123




      24.1k1375123










      asked May 28 at 13:06









      Racer SQLRacer SQL

      3,17742868




      3,17742868




















          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/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%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

                24.1k1375123




                24.1k1375123



























                    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

                    Club Baloncesto Breogán Índice Historia | Pavillón | Nome | O Breogán na cultura popular | Xogadores | Adestradores | Presidentes | Palmarés | Historial | Líderes | Notas | Véxase tamén | Menú de navegacióncbbreogan.galCadroGuía oficial da ACB 2009-10, páxina 201Guía oficial ACB 1992, páxina 183. Editorial DB.É de 6.500 espectadores sentados axeitándose á última normativa"Estudiantes Junior, entre as mellores canteiras"o orixinalHemeroteca El Mundo Deportivo, 16 setembro de 1970, páxina 12Historia do BreogánAlfredo Pérez, o último canoneiroHistoria C.B. BreogánHemeroteca de El Mundo DeportivoJimmy Wright, norteamericano do Breogán deixará Lugo por ameazas de morteResultados de Breogán en 1986-87Resultados de Breogán en 1990-91Ficha de Velimir Perasović en acb.comResultados de Breogán en 1994-95Breogán arrasa al Barça. "El Mundo Deportivo", 27 de setembro de 1999, páxina 58CB Breogán - FC BarcelonaA FEB invita a participar nunha nova Liga EuropeaCharlie Bell na prensa estatalMáximos anotadores 2005Tempada 2005-06 : Tódolos Xogadores da Xornada""Non quero pensar nunha man negra, mais pregúntome que está a pasar""o orixinalRaúl López, orgulloso dos xogadores, presume da boa saúde económica do BreogánJulio González confirma que cesa como presidente del BreogánHomenaxe a Lisardo GómezA tempada do rexurdimento celesteEntrevista a Lisardo GómezEl COB dinamita el Pazo para forzar el quinto (69-73)Cafés Candelas, patrocinador del CB Breogán"Suso Lázare, novo presidente do Breogán"o orixinalCafés Candelas Breogán firma el mayor triunfo de la historiaEl Breogán realizará 17 homenajes por su cincuenta aniversario"O Breogán honra ao seu fundador e primeiro presidente"o orixinalMiguel Giao recibiu a homenaxe do PazoHomenaxe aos primeiros gladiadores celestesO home que nos amosa como ver o Breo co corazónTita Franco será homenaxeada polos #50anosdeBreoJulio Vila recibirá unha homenaxe in memoriam polos #50anosdeBreo"O Breogán homenaxeará aos seus aboados máis veteráns"Pechada ovación a «Capi» Sanmartín e Ricardo «Corazón de González»Homenaxe por décadas de informaciónPaco García volve ao Pazo con motivo do 50 aniversario"Resultados y clasificaciones""O Cafés Candelas Breogán, campión da Copa Princesa""O Cafés Candelas Breogán, equipo ACB"C.B. Breogán"Proxecto social"o orixinal"Centros asociados"o orixinalFicha en imdb.comMario Camus trata la recuperación del amor en 'La vieja música', su última película"Páxina web oficial""Club Baloncesto Breogán""C. B. Breogán S.A.D."eehttp://www.fegaba.com

                    Vilaño, A Laracha Índice Patrimonio | Lugares e parroquias | Véxase tamén | Menú de navegación43°14′52″N 8°36′03″O / 43.24775, -8.60070

                    Cegueira Índice Epidemioloxía | Deficiencia visual | Tipos de cegueira | Principais causas de cegueira | Tratamento | Técnicas de adaptación e axudas | Vida dos cegos | Primeiros auxilios | Crenzas respecto das persoas cegas | Crenzas das persoas cegas | O neno deficiente visual | Aspectos psicolóxicos da cegueira | Notas | Véxase tamén | Menú de navegación54.054.154.436928256blindnessDicionario da Real Academia GalegaPortal das Palabras"International Standards: Visual Standards — Aspects and Ranges of Vision Loss with Emphasis on Population Surveys.""Visual impairment and blindness""Presentan un plan para previr a cegueira"o orixinalACCDV Associació Catalana de Cecs i Disminuïts Visuals - PMFTrachoma"Effect of gene therapy on visual function in Leber's congenital amaurosis"1844137110.1056/NEJMoa0802268Cans guía - os mellores amigos dos cegosArquivadoEscola de cans guía para cegos en Mortágua, PortugalArquivado"Tecnología para ciegos y deficientes visuales. Recopilación de recursos gratuitos en la Red""Colorino""‘COL.diesis’, escuchar los sonidos del color""COL.diesis: Transforming Colour into Melody and Implementing the Result in a Colour Sensor Device"o orixinal"Sistema de desarrollo de sinestesia color-sonido para invidentes utilizando un protocolo de audio""Enseñanza táctil - geometría y color. Juegos didácticos para niños ciegos y videntes""Sistema Constanz"L'ocupació laboral dels cecs a l'Estat espanyol està pràcticament equiparada a la de les persones amb visió, entrevista amb Pedro ZuritaONCE (Organización Nacional de Cegos de España)Prevención da cegueiraDescrición de deficiencias visuais (Disc@pnet)Braillín, un boneco atractivo para calquera neno, con ou sen discapacidade, que permite familiarizarse co sistema de escritura e lectura brailleAxudas Técnicas36838ID00897494007150-90057129528256DOID:1432HP:0000618D001766C10.597.751.941.162C97109C0155020