How could I select a column based on another column in mySQL?












1















The following script works fine. But I want to write it in one line rather than three lines. 'Size" is passed from my main program and its used here to test. Simply I want to get Price based on size.



Table columns :
LISTING_ID, PRICE_LARGE_PRICE, PRICE_SMALL_PRICE.



SET @Size = 'SMALL';

SELECT
PRICE_LARGE_PRICE,PRICE_SMALL_PRICE
INTO
@PRICE_LARGE_PRICE,@PRICE_SMALL_PRICE
FROM
prices
WHERE
PRICE_LISTING_ID = 60;

SET @ITEM_PRICE = (CASE @Size WHEN 'REGULAR' THEN @PRICE_LARGE_PRICE
WHEN 'SMALL' THEN @PRICE_SMALL_PRICE
ELSE null
END);

SELECT @ITEM_PRICE;


Any help is appreciated.










share|improve this question



























    1















    The following script works fine. But I want to write it in one line rather than three lines. 'Size" is passed from my main program and its used here to test. Simply I want to get Price based on size.



    Table columns :
    LISTING_ID, PRICE_LARGE_PRICE, PRICE_SMALL_PRICE.



    SET @Size = 'SMALL';

    SELECT
    PRICE_LARGE_PRICE,PRICE_SMALL_PRICE
    INTO
    @PRICE_LARGE_PRICE,@PRICE_SMALL_PRICE
    FROM
    prices
    WHERE
    PRICE_LISTING_ID = 60;

    SET @ITEM_PRICE = (CASE @Size WHEN 'REGULAR' THEN @PRICE_LARGE_PRICE
    WHEN 'SMALL' THEN @PRICE_SMALL_PRICE
    ELSE null
    END);

    SELECT @ITEM_PRICE;


    Any help is appreciated.










    share|improve this question

























      1












      1








      1








      The following script works fine. But I want to write it in one line rather than three lines. 'Size" is passed from my main program and its used here to test. Simply I want to get Price based on size.



      Table columns :
      LISTING_ID, PRICE_LARGE_PRICE, PRICE_SMALL_PRICE.



      SET @Size = 'SMALL';

      SELECT
      PRICE_LARGE_PRICE,PRICE_SMALL_PRICE
      INTO
      @PRICE_LARGE_PRICE,@PRICE_SMALL_PRICE
      FROM
      prices
      WHERE
      PRICE_LISTING_ID = 60;

      SET @ITEM_PRICE = (CASE @Size WHEN 'REGULAR' THEN @PRICE_LARGE_PRICE
      WHEN 'SMALL' THEN @PRICE_SMALL_PRICE
      ELSE null
      END);

      SELECT @ITEM_PRICE;


      Any help is appreciated.










      share|improve this question














      The following script works fine. But I want to write it in one line rather than three lines. 'Size" is passed from my main program and its used here to test. Simply I want to get Price based on size.



      Table columns :
      LISTING_ID, PRICE_LARGE_PRICE, PRICE_SMALL_PRICE.



      SET @Size = 'SMALL';

      SELECT
      PRICE_LARGE_PRICE,PRICE_SMALL_PRICE
      INTO
      @PRICE_LARGE_PRICE,@PRICE_SMALL_PRICE
      FROM
      prices
      WHERE
      PRICE_LISTING_ID = 60;

      SET @ITEM_PRICE = (CASE @Size WHEN 'REGULAR' THEN @PRICE_LARGE_PRICE
      WHEN 'SMALL' THEN @PRICE_SMALL_PRICE
      ELSE null
      END);

      SELECT @ITEM_PRICE;


      Any help is appreciated.







      mysql select case case-when






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 21 '18 at 15:30









      PCGPCG

      112211




      112211
























          2 Answers
          2






          active

          oldest

          votes


















          1














          Following may work.



          SET @Size = 'SMALL';

          SELECT
          PRICE_LARGE_PRICE,
          PRICE_SMALL_PRICE,
          CASE WHEN @Size = 'REGULAR' THEN PRICE_LARGE_PRICE
          WHEN @Size = 'SMALL' THEN PRICE_SMALL_PRICE
          END AS ITEM_PRICE
          INTO
          @PRICE_LARGE_PRICE,
          @PRICE_SMALL_PRICE,
          @ITEM_PRICE
          FROM
          prices
          WHERE
          PRICE_LISTING_ID = 60;





          share|improve this answer































            1














            I think you want



            SELECT 
            IF(@size == 'SMALL', PRICE_SMALL_PRICE, PRICE_LARGE_PRICE) AS ITEM_PRICE
            FROM prices;





            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%2f53415405%2fhow-could-i-select-a-column-based-on-another-column-in-mysql%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









              1














              Following may work.



              SET @Size = 'SMALL';

              SELECT
              PRICE_LARGE_PRICE,
              PRICE_SMALL_PRICE,
              CASE WHEN @Size = 'REGULAR' THEN PRICE_LARGE_PRICE
              WHEN @Size = 'SMALL' THEN PRICE_SMALL_PRICE
              END AS ITEM_PRICE
              INTO
              @PRICE_LARGE_PRICE,
              @PRICE_SMALL_PRICE,
              @ITEM_PRICE
              FROM
              prices
              WHERE
              PRICE_LISTING_ID = 60;





              share|improve this answer




























                1














                Following may work.



                SET @Size = 'SMALL';

                SELECT
                PRICE_LARGE_PRICE,
                PRICE_SMALL_PRICE,
                CASE WHEN @Size = 'REGULAR' THEN PRICE_LARGE_PRICE
                WHEN @Size = 'SMALL' THEN PRICE_SMALL_PRICE
                END AS ITEM_PRICE
                INTO
                @PRICE_LARGE_PRICE,
                @PRICE_SMALL_PRICE,
                @ITEM_PRICE
                FROM
                prices
                WHERE
                PRICE_LISTING_ID = 60;





                share|improve this answer


























                  1












                  1








                  1







                  Following may work.



                  SET @Size = 'SMALL';

                  SELECT
                  PRICE_LARGE_PRICE,
                  PRICE_SMALL_PRICE,
                  CASE WHEN @Size = 'REGULAR' THEN PRICE_LARGE_PRICE
                  WHEN @Size = 'SMALL' THEN PRICE_SMALL_PRICE
                  END AS ITEM_PRICE
                  INTO
                  @PRICE_LARGE_PRICE,
                  @PRICE_SMALL_PRICE,
                  @ITEM_PRICE
                  FROM
                  prices
                  WHERE
                  PRICE_LISTING_ID = 60;





                  share|improve this answer













                  Following may work.



                  SET @Size = 'SMALL';

                  SELECT
                  PRICE_LARGE_PRICE,
                  PRICE_SMALL_PRICE,
                  CASE WHEN @Size = 'REGULAR' THEN PRICE_LARGE_PRICE
                  WHEN @Size = 'SMALL' THEN PRICE_SMALL_PRICE
                  END AS ITEM_PRICE
                  INTO
                  @PRICE_LARGE_PRICE,
                  @PRICE_SMALL_PRICE,
                  @ITEM_PRICE
                  FROM
                  prices
                  WHERE
                  PRICE_LISTING_ID = 60;






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 21 '18 at 19:42









                  Madhur BhaiyaMadhur Bhaiya

                  19.6k62236




                  19.6k62236

























                      1














                      I think you want



                      SELECT 
                      IF(@size == 'SMALL', PRICE_SMALL_PRICE, PRICE_LARGE_PRICE) AS ITEM_PRICE
                      FROM prices;





                      share|improve this answer






























                        1














                        I think you want



                        SELECT 
                        IF(@size == 'SMALL', PRICE_SMALL_PRICE, PRICE_LARGE_PRICE) AS ITEM_PRICE
                        FROM prices;





                        share|improve this answer




























                          1












                          1








                          1







                          I think you want



                          SELECT 
                          IF(@size == 'SMALL', PRICE_SMALL_PRICE, PRICE_LARGE_PRICE) AS ITEM_PRICE
                          FROM prices;





                          share|improve this answer















                          I think you want



                          SELECT 
                          IF(@size == 'SMALL', PRICE_SMALL_PRICE, PRICE_LARGE_PRICE) AS ITEM_PRICE
                          FROM prices;






                          share|improve this answer














                          share|improve this answer



                          share|improve this answer








                          edited Nov 22 '18 at 15:07









                          PCG

                          112211




                          112211










                          answered Nov 21 '18 at 17:10









                          EvertEvert

                          41.3k1570125




                          41.3k1570125






























                              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%2f53415405%2fhow-could-i-select-a-column-based-on-another-column-in-mysql%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

                              MongoDB - Not Authorized To Execute Command

                              in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

                              How to fix TextFormField cause rebuild widget in Flutter