Insert into select with a hard coded value with Ruby Sequel











up vote
0
down vote

favorite












I am using Ruby Sequel to move data into reporting tables daily. I am consolidating data from three tables into a single table. I am doing this in Redshift so I have to use disable_insert_returning. The names of the columns in the two tables match each other but not the end table which means I am using graph and set_graph_aliases.



reports = db[:reports]
report_columns = [:user_id, :purchase_date, :sku]

spoons_select_graph = {
user_id: :users,
purchase_date: :spoon_receipts,
product_id: :spoon_receipts
}
spoons = db[:spoon_receipts]
spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

forks_select_graph = {
user_id: :users,
purchase_date: :fork_receipts,
product_id: :fork_receipts
}
forks = db[:fork_receipts]
forks_select = forks.graph(:users, user_id: :user_id).set_graph_aliases(forks_select_graph)

reports.disable_insert_returning.insert(report_columns, spoons_select)
reports.where(channel: nil).update(channel: 'spoons')
reports.disable_insert_returning.insert(report_columns, forks_select)
reports.where(channel: nil).update(channel: 'forks')


The updates are taking forever. What I would like to do is add the channel to the insert select so that I don't have to go back and update.










share|improve this question




























    up vote
    0
    down vote

    favorite












    I am using Ruby Sequel to move data into reporting tables daily. I am consolidating data from three tables into a single table. I am doing this in Redshift so I have to use disable_insert_returning. The names of the columns in the two tables match each other but not the end table which means I am using graph and set_graph_aliases.



    reports = db[:reports]
    report_columns = [:user_id, :purchase_date, :sku]

    spoons_select_graph = {
    user_id: :users,
    purchase_date: :spoon_receipts,
    product_id: :spoon_receipts
    }
    spoons = db[:spoon_receipts]
    spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

    forks_select_graph = {
    user_id: :users,
    purchase_date: :fork_receipts,
    product_id: :fork_receipts
    }
    forks = db[:fork_receipts]
    forks_select = forks.graph(:users, user_id: :user_id).set_graph_aliases(forks_select_graph)

    reports.disable_insert_returning.insert(report_columns, spoons_select)
    reports.where(channel: nil).update(channel: 'spoons')
    reports.disable_insert_returning.insert(report_columns, forks_select)
    reports.where(channel: nil).update(channel: 'forks')


    The updates are taking forever. What I would like to do is add the channel to the insert select so that I don't have to go back and update.










    share|improve this question


























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      I am using Ruby Sequel to move data into reporting tables daily. I am consolidating data from three tables into a single table. I am doing this in Redshift so I have to use disable_insert_returning. The names of the columns in the two tables match each other but not the end table which means I am using graph and set_graph_aliases.



      reports = db[:reports]
      report_columns = [:user_id, :purchase_date, :sku]

      spoons_select_graph = {
      user_id: :users,
      purchase_date: :spoon_receipts,
      product_id: :spoon_receipts
      }
      spoons = db[:spoon_receipts]
      spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

      forks_select_graph = {
      user_id: :users,
      purchase_date: :fork_receipts,
      product_id: :fork_receipts
      }
      forks = db[:fork_receipts]
      forks_select = forks.graph(:users, user_id: :user_id).set_graph_aliases(forks_select_graph)

      reports.disable_insert_returning.insert(report_columns, spoons_select)
      reports.where(channel: nil).update(channel: 'spoons')
      reports.disable_insert_returning.insert(report_columns, forks_select)
      reports.where(channel: nil).update(channel: 'forks')


      The updates are taking forever. What I would like to do is add the channel to the insert select so that I don't have to go back and update.










      share|improve this question















      I am using Ruby Sequel to move data into reporting tables daily. I am consolidating data from three tables into a single table. I am doing this in Redshift so I have to use disable_insert_returning. The names of the columns in the two tables match each other but not the end table which means I am using graph and set_graph_aliases.



      reports = db[:reports]
      report_columns = [:user_id, :purchase_date, :sku]

      spoons_select_graph = {
      user_id: :users,
      purchase_date: :spoon_receipts,
      product_id: :spoon_receipts
      }
      spoons = db[:spoon_receipts]
      spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

      forks_select_graph = {
      user_id: :users,
      purchase_date: :fork_receipts,
      product_id: :fork_receipts
      }
      forks = db[:fork_receipts]
      forks_select = forks.graph(:users, user_id: :user_id).set_graph_aliases(forks_select_graph)

      reports.disable_insert_returning.insert(report_columns, spoons_select)
      reports.where(channel: nil).update(channel: 'spoons')
      reports.disable_insert_returning.insert(report_columns, forks_select)
      reports.where(channel: nil).update(channel: 'forks')


      The updates are taking forever. What I would like to do is add the channel to the insert select so that I don't have to go back and update.







      ruby amazon-redshift sequel






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 19 at 14:48

























      asked Nov 19 at 14:22









      Sixty4Bit

      5,054103854




      5,054103854
























          1 Answer
          1






          active

          oldest

          votes

















          up vote
          1
          down vote



          accepted
          +150










          You didn't provide an executable setup, so I haven't tested this, but I think it will work. The basic idea is to just add a constant column of results to your select.



          reports = db[:reports]
          report_columns = [:user_id, :purchase_date, :sku, :channel]

          spoons_select_graph = {
          user_id: :users,
          purchase_date: :spoon_receipts,
          product_id: :spoon_receipts,
          channel: [:spoon_receipts, :channel, 'spoons']
          }
          spoons = db[:spoon_receipts]
          spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

          reports.disable_insert_returning.insert(report_columns, spoons_select)


          See the documentation for set_graph_aliases for more information.






          share|improve this answer





















          • Thank you! I missed this in the documentation!
            – Sixty4Bit
            Nov 25 at 15:59










          • @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
            – Old Pro
            Nov 26 at 0:58










          • you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
            – Sixty4Bit
            Nov 26 at 4:06











          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',
          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%2f53376639%2finsert-into-select-with-a-hard-coded-value-with-ruby-sequel%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








          up vote
          1
          down vote



          accepted
          +150










          You didn't provide an executable setup, so I haven't tested this, but I think it will work. The basic idea is to just add a constant column of results to your select.



          reports = db[:reports]
          report_columns = [:user_id, :purchase_date, :sku, :channel]

          spoons_select_graph = {
          user_id: :users,
          purchase_date: :spoon_receipts,
          product_id: :spoon_receipts,
          channel: [:spoon_receipts, :channel, 'spoons']
          }
          spoons = db[:spoon_receipts]
          spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

          reports.disable_insert_returning.insert(report_columns, spoons_select)


          See the documentation for set_graph_aliases for more information.






          share|improve this answer





















          • Thank you! I missed this in the documentation!
            – Sixty4Bit
            Nov 25 at 15:59










          • @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
            – Old Pro
            Nov 26 at 0:58










          • you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
            – Sixty4Bit
            Nov 26 at 4:06















          up vote
          1
          down vote



          accepted
          +150










          You didn't provide an executable setup, so I haven't tested this, but I think it will work. The basic idea is to just add a constant column of results to your select.



          reports = db[:reports]
          report_columns = [:user_id, :purchase_date, :sku, :channel]

          spoons_select_graph = {
          user_id: :users,
          purchase_date: :spoon_receipts,
          product_id: :spoon_receipts,
          channel: [:spoon_receipts, :channel, 'spoons']
          }
          spoons = db[:spoon_receipts]
          spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

          reports.disable_insert_returning.insert(report_columns, spoons_select)


          See the documentation for set_graph_aliases for more information.






          share|improve this answer





















          • Thank you! I missed this in the documentation!
            – Sixty4Bit
            Nov 25 at 15:59










          • @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
            – Old Pro
            Nov 26 at 0:58










          • you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
            – Sixty4Bit
            Nov 26 at 4:06













          up vote
          1
          down vote



          accepted
          +150







          up vote
          1
          down vote



          accepted
          +150




          +150




          You didn't provide an executable setup, so I haven't tested this, but I think it will work. The basic idea is to just add a constant column of results to your select.



          reports = db[:reports]
          report_columns = [:user_id, :purchase_date, :sku, :channel]

          spoons_select_graph = {
          user_id: :users,
          purchase_date: :spoon_receipts,
          product_id: :spoon_receipts,
          channel: [:spoon_receipts, :channel, 'spoons']
          }
          spoons = db[:spoon_receipts]
          spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

          reports.disable_insert_returning.insert(report_columns, spoons_select)


          See the documentation for set_graph_aliases for more information.






          share|improve this answer












          You didn't provide an executable setup, so I haven't tested this, but I think it will work. The basic idea is to just add a constant column of results to your select.



          reports = db[:reports]
          report_columns = [:user_id, :purchase_date, :sku, :channel]

          spoons_select_graph = {
          user_id: :users,
          purchase_date: :spoon_receipts,
          product_id: :spoon_receipts,
          channel: [:spoon_receipts, :channel, 'spoons']
          }
          spoons = db[:spoon_receipts]
          spoons_select = spoons.graph(:users, user_id: :user_id).set_graph_aliases(spoons_select_graph)

          reports.disable_insert_returning.insert(report_columns, spoons_select)


          See the documentation for set_graph_aliases for more information.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 23 at 4:16









          Old Pro

          12.9k23663




          12.9k23663












          • Thank you! I missed this in the documentation!
            – Sixty4Bit
            Nov 25 at 15:59










          • @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
            – Old Pro
            Nov 26 at 0:58










          • you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
            – Sixty4Bit
            Nov 26 at 4:06


















          • Thank you! I missed this in the documentation!
            – Sixty4Bit
            Nov 25 at 15:59










          • @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
            – Old Pro
            Nov 26 at 0:58










          • you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
            – Sixty4Bit
            Nov 26 at 4:06
















          Thank you! I missed this in the documentation!
          – Sixty4Bit
          Nov 25 at 15:59




          Thank you! I missed this in the documentation!
          – Sixty4Bit
          Nov 25 at 15:59












          @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
          – Old Pro
          Nov 26 at 0:58




          @Sixty4Bit thank you for the bounty and I'm glad I could help. Please also mark the answer as accepted (click the big checkmark) so that when the question shows up in future searches, people see it has an accepted answer.
          – Old Pro
          Nov 26 at 0:58












          you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
          – Sixty4Bit
          Nov 26 at 4:06




          you would think awarding the bounty would have accepted the answer as well. Odd. Thanks for the heads up.
          – Sixty4Bit
          Nov 26 at 4:06


















          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.





          Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


          Please pay close attention to the following guidance:


          • 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%2f53376639%2finsert-into-select-with-a-hard-coded-value-with-ruby-sequel%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

          Create new schema in PostgreSQL using DBeaver

          Deepest pit of an array with Javascript: test on Codility

          Costa Masnaga