create and update column in MySQL











up vote
0
down vote

favorite












I need this code to create one column and then make it another foreign key.



I do not want another code, I need this for certain reasons. How can I add code to modify the created column and make it a foreign key?



-- Actualizando la tabla: action

DELIMITER $$
SET @s = (SELECT IF(
(SELECT COUNT(*)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE table_name = 'action'
AND table_schema = 'ibexsales_dev'
AND column_name = 'company_id'
) > 0,
"SELECT 1",
"ALTER TABLE action ADD company_id INT(11) NOT NULL"
));
PREPARE stmt FROM @s;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
$$ DELIMITER ;


I need add this code:



ALTER TABLE `ibexsales_dev`.`action` 
ADD CONSTRAINT `fk_company_id_action`
FOREIGN KEY (`company_id`) REFERENCES company(`company_id`);


I tried this but it does not work:



) > 0,
"SELECT 1",
"ALTER TABLE action ADD company_id INT(11) NOT NULL",
" ALTER TABLE `ibexsales_dev`.`action`
ADD CONSTRAINT `fk_company_id_action`
FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
));









share|improve this question


























    up vote
    0
    down vote

    favorite












    I need this code to create one column and then make it another foreign key.



    I do not want another code, I need this for certain reasons. How can I add code to modify the created column and make it a foreign key?



    -- Actualizando la tabla: action

    DELIMITER $$
    SET @s = (SELECT IF(
    (SELECT COUNT(*)
    FROM INFORMATION_SCHEMA.COLUMNS
    WHERE table_name = 'action'
    AND table_schema = 'ibexsales_dev'
    AND column_name = 'company_id'
    ) > 0,
    "SELECT 1",
    "ALTER TABLE action ADD company_id INT(11) NOT NULL"
    ));
    PREPARE stmt FROM @s;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    $$ DELIMITER ;


    I need add this code:



    ALTER TABLE `ibexsales_dev`.`action` 
    ADD CONSTRAINT `fk_company_id_action`
    FOREIGN KEY (`company_id`) REFERENCES company(`company_id`);


    I tried this but it does not work:



    ) > 0,
    "SELECT 1",
    "ALTER TABLE action ADD company_id INT(11) NOT NULL",
    " ALTER TABLE `ibexsales_dev`.`action`
    ADD CONSTRAINT `fk_company_id_action`
    FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
    ));









    share|improve this question
























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      I need this code to create one column and then make it another foreign key.



      I do not want another code, I need this for certain reasons. How can I add code to modify the created column and make it a foreign key?



      -- Actualizando la tabla: action

      DELIMITER $$
      SET @s = (SELECT IF(
      (SELECT COUNT(*)
      FROM INFORMATION_SCHEMA.COLUMNS
      WHERE table_name = 'action'
      AND table_schema = 'ibexsales_dev'
      AND column_name = 'company_id'
      ) > 0,
      "SELECT 1",
      "ALTER TABLE action ADD company_id INT(11) NOT NULL"
      ));
      PREPARE stmt FROM @s;
      EXECUTE stmt;
      DEALLOCATE PREPARE stmt;
      $$ DELIMITER ;


      I need add this code:



      ALTER TABLE `ibexsales_dev`.`action` 
      ADD CONSTRAINT `fk_company_id_action`
      FOREIGN KEY (`company_id`) REFERENCES company(`company_id`);


      I tried this but it does not work:



      ) > 0,
      "SELECT 1",
      "ALTER TABLE action ADD company_id INT(11) NOT NULL",
      " ALTER TABLE `ibexsales_dev`.`action`
      ADD CONSTRAINT `fk_company_id_action`
      FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
      ));









      share|improve this question













      I need this code to create one column and then make it another foreign key.



      I do not want another code, I need this for certain reasons. How can I add code to modify the created column and make it a foreign key?



      -- Actualizando la tabla: action

      DELIMITER $$
      SET @s = (SELECT IF(
      (SELECT COUNT(*)
      FROM INFORMATION_SCHEMA.COLUMNS
      WHERE table_name = 'action'
      AND table_schema = 'ibexsales_dev'
      AND column_name = 'company_id'
      ) > 0,
      "SELECT 1",
      "ALTER TABLE action ADD company_id INT(11) NOT NULL"
      ));
      PREPARE stmt FROM @s;
      EXECUTE stmt;
      DEALLOCATE PREPARE stmt;
      $$ DELIMITER ;


      I need add this code:



      ALTER TABLE `ibexsales_dev`.`action` 
      ADD CONSTRAINT `fk_company_id_action`
      FOREIGN KEY (`company_id`) REFERENCES company(`company_id`);


      I tried this but it does not work:



      ) > 0,
      "SELECT 1",
      "ALTER TABLE action ADD company_id INT(11) NOT NULL",
      " ALTER TABLE `ibexsales_dev`.`action`
      ADD CONSTRAINT `fk_company_id_action`
      FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
      ));






      mysql mysql-workbench






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked 11 hours ago









      Carlos

      445




      445
























          1 Answer
          1






          active

          oldest

          votes

















          up vote
          1
          down vote



          accepted










          You don't repeat ALTER TABLE. A single ALTER TABLE query can contain multiple alterations, separated by comma.



          ) > 0,
          "SELECT 1",
          "ALTER TABLE action ADD company_id INT(11) NOT NULL,
          ADD CONSTRAINT `fk_company_id_action`
          FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
          ));





          share|improve this answer





















          • Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
            – Carlos
            11 hours ago










          • You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
            – Barmar
            6 hours ago










          • Thank you :) :)
            – Carlos
            5 hours ago











          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%2f53371879%2fcreate-and-update-column-in-mysql%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










          You don't repeat ALTER TABLE. A single ALTER TABLE query can contain multiple alterations, separated by comma.



          ) > 0,
          "SELECT 1",
          "ALTER TABLE action ADD company_id INT(11) NOT NULL,
          ADD CONSTRAINT `fk_company_id_action`
          FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
          ));





          share|improve this answer





















          • Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
            – Carlos
            11 hours ago










          • You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
            – Barmar
            6 hours ago










          • Thank you :) :)
            – Carlos
            5 hours ago















          up vote
          1
          down vote



          accepted










          You don't repeat ALTER TABLE. A single ALTER TABLE query can contain multiple alterations, separated by comma.



          ) > 0,
          "SELECT 1",
          "ALTER TABLE action ADD company_id INT(11) NOT NULL,
          ADD CONSTRAINT `fk_company_id_action`
          FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
          ));





          share|improve this answer





















          • Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
            – Carlos
            11 hours ago










          • You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
            – Barmar
            6 hours ago










          • Thank you :) :)
            – Carlos
            5 hours ago













          up vote
          1
          down vote



          accepted







          up vote
          1
          down vote



          accepted






          You don't repeat ALTER TABLE. A single ALTER TABLE query can contain multiple alterations, separated by comma.



          ) > 0,
          "SELECT 1",
          "ALTER TABLE action ADD company_id INT(11) NOT NULL,
          ADD CONSTRAINT `fk_company_id_action`
          FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
          ));





          share|improve this answer












          You don't repeat ALTER TABLE. A single ALTER TABLE query can contain multiple alterations, separated by comma.



          ) > 0,
          "SELECT 1",
          "ALTER TABLE action ADD company_id INT(11) NOT NULL,
          ADD CONSTRAINT `fk_company_id_action`
          FOREIGN KEY (`company_id`) REFERENCES company(`company_id`); "
          ));






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered 11 hours ago









          Barmar

          412k34237339




          412k34237339












          • Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
            – Carlos
            11 hours ago










          • You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
            – Barmar
            6 hours ago










          • Thank you :) :)
            – Carlos
            5 hours ago


















          • Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
            – Carlos
            11 hours ago










          • You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
            – Barmar
            6 hours ago










          • Thank you :) :)
            – Carlos
            5 hours ago
















          Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
          – Carlos
          11 hours ago




          Perfect, thank you. What is the name of the structure I used? (I did not know what could be done that way, I have seen the example on the internet)
          – Carlos
          11 hours ago












          You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
          – Barmar
          6 hours ago




          You had too many arguments to IF(). It's just IF(condition, trueResult, falseResult), but you had IF(condition, trueResult, falseResult, anotherFalseResult). The "name" is syntax error.
          – Barmar
          6 hours ago












          Thank you :) :)
          – Carlos
          5 hours ago




          Thank you :) :)
          – Carlos
          5 hours ago


















           

          draft saved


          draft discarded



















































           


          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53371879%2fcreate-and-update-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

          Can a sorcerer learn a 5th-level spell early by creating spell slots using the Font of Magic feature?

          Does disintegrating a polymorphed enemy still kill it after the 2018 errata?

          A Topological Invariant for $pi_3(U(n))$