PowerBI - Comparing two similar sets of data (Many to Many)





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}







0















I am trying to compare to sets of data that are very similar. I have done a bridge relation and used M:M relationship on PowerBI but I am still not getting the result I want.



Here is an example of the data:
Dataset 1



Name | Service | Usage 
A | 1 | 10
A | 2 | 20
B | 1 | 10
B | 2 | 10
C | 1 | 20
C | 2 | 10


Dataset 2



Name | Service | Usage 
A | 1 | 40
A | 2 | 20
B | 1 | 40
B | 2 | 10
C | 1 | 40
C | 2 | 10


Desired output



Name | Service | Usage 1 | Usage 2  
A | 1 | 10 | 40
A | 2 | 20 | 20
B | 1 | 10 | 40
B | 2 | 10 | 10
C | 1 | 20 | 40
C | 2 | 10 | 10


Is this possible in PowerBI?










share|improve this question

























  • Instead of a bridge, create 2 dimensions: one with names. and one with services, and connect them to both tables (as 1:M relations). Then you will be able to drill across easily.

    – RADO
    Nov 21 '18 at 23:35


















0















I am trying to compare to sets of data that are very similar. I have done a bridge relation and used M:M relationship on PowerBI but I am still not getting the result I want.



Here is an example of the data:
Dataset 1



Name | Service | Usage 
A | 1 | 10
A | 2 | 20
B | 1 | 10
B | 2 | 10
C | 1 | 20
C | 2 | 10


Dataset 2



Name | Service | Usage 
A | 1 | 40
A | 2 | 20
B | 1 | 40
B | 2 | 10
C | 1 | 40
C | 2 | 10


Desired output



Name | Service | Usage 1 | Usage 2  
A | 1 | 10 | 40
A | 2 | 20 | 20
B | 1 | 10 | 40
B | 2 | 10 | 10
C | 1 | 20 | 40
C | 2 | 10 | 10


Is this possible in PowerBI?










share|improve this question

























  • Instead of a bridge, create 2 dimensions: one with names. and one with services, and connect them to both tables (as 1:M relations). Then you will be able to drill across easily.

    – RADO
    Nov 21 '18 at 23:35














0












0








0








I am trying to compare to sets of data that are very similar. I have done a bridge relation and used M:M relationship on PowerBI but I am still not getting the result I want.



Here is an example of the data:
Dataset 1



Name | Service | Usage 
A | 1 | 10
A | 2 | 20
B | 1 | 10
B | 2 | 10
C | 1 | 20
C | 2 | 10


Dataset 2



Name | Service | Usage 
A | 1 | 40
A | 2 | 20
B | 1 | 40
B | 2 | 10
C | 1 | 40
C | 2 | 10


Desired output



Name | Service | Usage 1 | Usage 2  
A | 1 | 10 | 40
A | 2 | 20 | 20
B | 1 | 10 | 40
B | 2 | 10 | 10
C | 1 | 20 | 40
C | 2 | 10 | 10


Is this possible in PowerBI?










share|improve this question
















I am trying to compare to sets of data that are very similar. I have done a bridge relation and used M:M relationship on PowerBI but I am still not getting the result I want.



Here is an example of the data:
Dataset 1



Name | Service | Usage 
A | 1 | 10
A | 2 | 20
B | 1 | 10
B | 2 | 10
C | 1 | 20
C | 2 | 10


Dataset 2



Name | Service | Usage 
A | 1 | 40
A | 2 | 20
B | 1 | 40
B | 2 | 10
C | 1 | 40
C | 2 | 10


Desired output



Name | Service | Usage 1 | Usage 2  
A | 1 | 10 | 40
A | 2 | 20 | 20
B | 1 | 10 | 40
B | 2 | 10 | 10
C | 1 | 20 | 40
C | 2 | 10 | 10


Is this possible in PowerBI?







powerbi






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 21 '18 at 21:21







Heng Yon

















asked Nov 21 '18 at 21:04









Heng YonHeng Yon

32




32













  • Instead of a bridge, create 2 dimensions: one with names. and one with services, and connect them to both tables (as 1:M relations). Then you will be able to drill across easily.

    – RADO
    Nov 21 '18 at 23:35



















  • Instead of a bridge, create 2 dimensions: one with names. and one with services, and connect them to both tables (as 1:M relations). Then you will be able to drill across easily.

    – RADO
    Nov 21 '18 at 23:35

















Instead of a bridge, create 2 dimensions: one with names. and one with services, and connect them to both tables (as 1:M relations). Then you will be able to drill across easily.

– RADO
Nov 21 '18 at 23:35





Instead of a bridge, create 2 dimensions: one with names. and one with services, and connect them to both tables (as 1:M relations). Then you will be able to drill across easily.

– RADO
Nov 21 '18 at 23:35












2 Answers
2






active

oldest

votes


















0














One approach (as suggested in comments), is to separate the distinct Name and Service values into separate dimension tables, in the query editor:



Names:



= Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Name], #"Dataset 2"[Name]})),Splitter.SplitByNothing(),{"Name"})


Services:



= Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Service], #"Dataset 2"[Service]})),Splitter.SplitByNothing(),{"Service"})


Create the DAX measures you want:



Usage 1 = SUM ( 'Dataset 1'[Usage] )



Usage 2 = SUM ( 'Dataset 2'[Usage] )



Now create relationships between the fact tables (Dataset 1, Dataset 2) and the dimension tables (Names, Services):



enter image description here



Then simply layout the visual as required:



enter image description here






share|improve this answer































    0














    Another approach may be to combine your dataset fact tables into one table, with an added "dataset" column:



    Create your "combined" table in the query editor.



    Combined Table:



    = Table.Combine({Table.AddColumn(#"Dataset 1", "Dataset", each "Dataset 1", type text), Table.AddColumn(#"Dataset 2", "Dataset", each "Dataset 2", type text)})


    Now use this table as your single source - either with a crosstab visual:



    enter image description here



    Or by adding separate measure for each dataset:



    Usage 1 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 1" )



    Usage 2 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 2" )



    enter image description here






    share|improve this answer
























      Your Answer






      StackExchange.ifUsing("editor", function () {
      StackExchange.using("externalEditor", function () {
      StackExchange.using("snippets", function () {
      StackExchange.snippets.init();
      });
      });
      }, "code-snippets");

      StackExchange.ready(function() {
      var channelOptions = {
      tags: "".split(" "),
      id: "1"
      };
      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: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      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%2fstackoverflow.com%2fquestions%2f53420455%2fpowerbi-comparing-two-similar-sets-of-data-many-to-many%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









      0














      One approach (as suggested in comments), is to separate the distinct Name and Service values into separate dimension tables, in the query editor:



      Names:



      = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Name], #"Dataset 2"[Name]})),Splitter.SplitByNothing(),{"Name"})


      Services:



      = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Service], #"Dataset 2"[Service]})),Splitter.SplitByNothing(),{"Service"})


      Create the DAX measures you want:



      Usage 1 = SUM ( 'Dataset 1'[Usage] )



      Usage 2 = SUM ( 'Dataset 2'[Usage] )



      Now create relationships between the fact tables (Dataset 1, Dataset 2) and the dimension tables (Names, Services):



      enter image description here



      Then simply layout the visual as required:



      enter image description here






      share|improve this answer




























        0














        One approach (as suggested in comments), is to separate the distinct Name and Service values into separate dimension tables, in the query editor:



        Names:



        = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Name], #"Dataset 2"[Name]})),Splitter.SplitByNothing(),{"Name"})


        Services:



        = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Service], #"Dataset 2"[Service]})),Splitter.SplitByNothing(),{"Service"})


        Create the DAX measures you want:



        Usage 1 = SUM ( 'Dataset 1'[Usage] )



        Usage 2 = SUM ( 'Dataset 2'[Usage] )



        Now create relationships between the fact tables (Dataset 1, Dataset 2) and the dimension tables (Names, Services):



        enter image description here



        Then simply layout the visual as required:



        enter image description here






        share|improve this answer


























          0












          0








          0







          One approach (as suggested in comments), is to separate the distinct Name and Service values into separate dimension tables, in the query editor:



          Names:



          = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Name], #"Dataset 2"[Name]})),Splitter.SplitByNothing(),{"Name"})


          Services:



          = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Service], #"Dataset 2"[Service]})),Splitter.SplitByNothing(),{"Service"})


          Create the DAX measures you want:



          Usage 1 = SUM ( 'Dataset 1'[Usage] )



          Usage 2 = SUM ( 'Dataset 2'[Usage] )



          Now create relationships between the fact tables (Dataset 1, Dataset 2) and the dimension tables (Names, Services):



          enter image description here



          Then simply layout the visual as required:



          enter image description here






          share|improve this answer













          One approach (as suggested in comments), is to separate the distinct Name and Service values into separate dimension tables, in the query editor:



          Names:



          = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Name], #"Dataset 2"[Name]})),Splitter.SplitByNothing(),{"Name"})


          Services:



          = Table.FromList(List.Distinct(List.Combine({#"Dataset 1"[Service], #"Dataset 2"[Service]})),Splitter.SplitByNothing(),{"Service"})


          Create the DAX measures you want:



          Usage 1 = SUM ( 'Dataset 1'[Usage] )



          Usage 2 = SUM ( 'Dataset 2'[Usage] )



          Now create relationships between the fact tables (Dataset 1, Dataset 2) and the dimension tables (Names, Services):



          enter image description here



          Then simply layout the visual as required:



          enter image description here







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 22 '18 at 10:25









          OllyOlly

          4,54211028




          4,54211028

























              0














              Another approach may be to combine your dataset fact tables into one table, with an added "dataset" column:



              Create your "combined" table in the query editor.



              Combined Table:



              = Table.Combine({Table.AddColumn(#"Dataset 1", "Dataset", each "Dataset 1", type text), Table.AddColumn(#"Dataset 2", "Dataset", each "Dataset 2", type text)})


              Now use this table as your single source - either with a crosstab visual:



              enter image description here



              Or by adding separate measure for each dataset:



              Usage 1 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 1" )



              Usage 2 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 2" )



              enter image description here






              share|improve this answer




























                0














                Another approach may be to combine your dataset fact tables into one table, with an added "dataset" column:



                Create your "combined" table in the query editor.



                Combined Table:



                = Table.Combine({Table.AddColumn(#"Dataset 1", "Dataset", each "Dataset 1", type text), Table.AddColumn(#"Dataset 2", "Dataset", each "Dataset 2", type text)})


                Now use this table as your single source - either with a crosstab visual:



                enter image description here



                Or by adding separate measure for each dataset:



                Usage 1 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 1" )



                Usage 2 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 2" )



                enter image description here






                share|improve this answer


























                  0












                  0








                  0







                  Another approach may be to combine your dataset fact tables into one table, with an added "dataset" column:



                  Create your "combined" table in the query editor.



                  Combined Table:



                  = Table.Combine({Table.AddColumn(#"Dataset 1", "Dataset", each "Dataset 1", type text), Table.AddColumn(#"Dataset 2", "Dataset", each "Dataset 2", type text)})


                  Now use this table as your single source - either with a crosstab visual:



                  enter image description here



                  Or by adding separate measure for each dataset:



                  Usage 1 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 1" )



                  Usage 2 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 2" )



                  enter image description here






                  share|improve this answer













                  Another approach may be to combine your dataset fact tables into one table, with an added "dataset" column:



                  Create your "combined" table in the query editor.



                  Combined Table:



                  = Table.Combine({Table.AddColumn(#"Dataset 1", "Dataset", each "Dataset 1", type text), Table.AddColumn(#"Dataset 2", "Dataset", each "Dataset 2", type text)})


                  Now use this table as your single source - either with a crosstab visual:



                  enter image description here



                  Or by adding separate measure for each dataset:



                  Usage 1 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 1" )



                  Usage 2 = CALCULATE ( SUM('Combined Data'[Usage]), 'Combined Data'[Dataset] = "Dataset 2" )



                  enter image description here







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 22 '18 at 10:36









                  OllyOlly

                  4,54211028




                  4,54211028






























                      draft saved

                      draft discarded




















































                      Thanks for contributing an answer to Stack Overflow!


                      • 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%2fstackoverflow.com%2fquestions%2f53420455%2fpowerbi-comparing-two-similar-sets-of-data-many-to-many%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

                      Guess what letter conforming each word

                      Run scheduled task as local user group (not BUILTIN)

                      Port of Spain