mysqli_query not processing correctly





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







1















I'm setting up a small signup form that should be inserting the data to an existing table, return the unique ID and insert that value to a secondary table.



Currently, I presume that the the first query is not running because the unique ID returned is 0.



I've gone over this small portion of code, that works on all my other developments and can't seem to figure out where it's blocking.



mysqli_query ($db_conx, "INSERT INTO Users
(first_name, last_name, dob, email, user_type, company, start_date, end_date, create_timestamp, last_modify_timestamp, create_matricule, pwd_hash)
VALUES
('$first_name','$last_name','$dob','$email','$user_type','$company','$start_date','$end_date','$create_timestamp','$create_timestamp','$create_matricule','$password_hash')");


//Now select this user to retreive the matricule

$matricule = mysqli_insert_id($db_conx);


$sql2 ="INSERT INTO Permissions (matricule) VALUES ('$matricule')";
$query2 = mysqli_query($db_conx, $sql2);

if(!$query){
echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
}

echo json_encode(['message'=>"Matricule ".$matricule." created", 'code'=>200]);

}


The console returns the following :



Object { message: "Matricule 0 created", code: 200 }
javascript.js:125:13
success javascript.js:126:13
ReferenceError: matricule is not defined[Learn More]


So therefore the creation to the second table works just fine but not the first.



My database is configured as follows:



CREATE TABLE `Users` (
`matricule` int(6) NOT NULL,
`first_name` varchar(35) NOT NULL,
`last_name` varchar(35) NOT NULL,
`dob` date NOT NULL,
`email` varchar(50) NOT NULL,
`user_type` varchar(3) NOT NULL,
`company` varchar(30) NOT NULL,
`start_date` date NOT NULL,
`end_date` date NOT NULL,
`pwd_hash` varchar(500) NOT NULL,
`pwd_reset_hash` varchar(100) NOT NULL,
`otp_token` varchar(6) NOT NULL,
`create_timestamp` datetime NOT NULL,
`create_matricule` varchar(7) NOT NULL,
`manager_matricule` varchar(7) NOT NULL,
`sq_1` varchar(2) NOT NULL,
`sa_1` varchar(50) NOT NULL,
`sq_2` varchar(2) NOT NULL,
`sa_2` varchar(50) NOT NULL,
`last_modify_timestamp` datetime NOT NULL,
`last_modify_matricule` varchar(7) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


Thanks for any input!!










share|improve this question























  • Note: do not concatenate strings to SQL queries. Use parameters. It will save you from a lot of headache

    – Sami Kuhmonen
    Jan 3 at 7:30


















1















I'm setting up a small signup form that should be inserting the data to an existing table, return the unique ID and insert that value to a secondary table.



Currently, I presume that the the first query is not running because the unique ID returned is 0.



I've gone over this small portion of code, that works on all my other developments and can't seem to figure out where it's blocking.



mysqli_query ($db_conx, "INSERT INTO Users
(first_name, last_name, dob, email, user_type, company, start_date, end_date, create_timestamp, last_modify_timestamp, create_matricule, pwd_hash)
VALUES
('$first_name','$last_name','$dob','$email','$user_type','$company','$start_date','$end_date','$create_timestamp','$create_timestamp','$create_matricule','$password_hash')");


//Now select this user to retreive the matricule

$matricule = mysqli_insert_id($db_conx);


$sql2 ="INSERT INTO Permissions (matricule) VALUES ('$matricule')";
$query2 = mysqli_query($db_conx, $sql2);

if(!$query){
echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
}

echo json_encode(['message'=>"Matricule ".$matricule." created", 'code'=>200]);

}


The console returns the following :



Object { message: "Matricule 0 created", code: 200 }
javascript.js:125:13
success javascript.js:126:13
ReferenceError: matricule is not defined[Learn More]


So therefore the creation to the second table works just fine but not the first.



My database is configured as follows:



CREATE TABLE `Users` (
`matricule` int(6) NOT NULL,
`first_name` varchar(35) NOT NULL,
`last_name` varchar(35) NOT NULL,
`dob` date NOT NULL,
`email` varchar(50) NOT NULL,
`user_type` varchar(3) NOT NULL,
`company` varchar(30) NOT NULL,
`start_date` date NOT NULL,
`end_date` date NOT NULL,
`pwd_hash` varchar(500) NOT NULL,
`pwd_reset_hash` varchar(100) NOT NULL,
`otp_token` varchar(6) NOT NULL,
`create_timestamp` datetime NOT NULL,
`create_matricule` varchar(7) NOT NULL,
`manager_matricule` varchar(7) NOT NULL,
`sq_1` varchar(2) NOT NULL,
`sa_1` varchar(50) NOT NULL,
`sq_2` varchar(2) NOT NULL,
`sa_2` varchar(50) NOT NULL,
`last_modify_timestamp` datetime NOT NULL,
`last_modify_matricule` varchar(7) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


Thanks for any input!!










share|improve this question























  • Note: do not concatenate strings to SQL queries. Use parameters. It will save you from a lot of headache

    – Sami Kuhmonen
    Jan 3 at 7:30














1












1








1








I'm setting up a small signup form that should be inserting the data to an existing table, return the unique ID and insert that value to a secondary table.



Currently, I presume that the the first query is not running because the unique ID returned is 0.



I've gone over this small portion of code, that works on all my other developments and can't seem to figure out where it's blocking.



mysqli_query ($db_conx, "INSERT INTO Users
(first_name, last_name, dob, email, user_type, company, start_date, end_date, create_timestamp, last_modify_timestamp, create_matricule, pwd_hash)
VALUES
('$first_name','$last_name','$dob','$email','$user_type','$company','$start_date','$end_date','$create_timestamp','$create_timestamp','$create_matricule','$password_hash')");


//Now select this user to retreive the matricule

$matricule = mysqli_insert_id($db_conx);


$sql2 ="INSERT INTO Permissions (matricule) VALUES ('$matricule')";
$query2 = mysqli_query($db_conx, $sql2);

if(!$query){
echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
}

echo json_encode(['message'=>"Matricule ".$matricule." created", 'code'=>200]);

}


The console returns the following :



Object { message: "Matricule 0 created", code: 200 }
javascript.js:125:13
success javascript.js:126:13
ReferenceError: matricule is not defined[Learn More]


So therefore the creation to the second table works just fine but not the first.



My database is configured as follows:



CREATE TABLE `Users` (
`matricule` int(6) NOT NULL,
`first_name` varchar(35) NOT NULL,
`last_name` varchar(35) NOT NULL,
`dob` date NOT NULL,
`email` varchar(50) NOT NULL,
`user_type` varchar(3) NOT NULL,
`company` varchar(30) NOT NULL,
`start_date` date NOT NULL,
`end_date` date NOT NULL,
`pwd_hash` varchar(500) NOT NULL,
`pwd_reset_hash` varchar(100) NOT NULL,
`otp_token` varchar(6) NOT NULL,
`create_timestamp` datetime NOT NULL,
`create_matricule` varchar(7) NOT NULL,
`manager_matricule` varchar(7) NOT NULL,
`sq_1` varchar(2) NOT NULL,
`sa_1` varchar(50) NOT NULL,
`sq_2` varchar(2) NOT NULL,
`sa_2` varchar(50) NOT NULL,
`last_modify_timestamp` datetime NOT NULL,
`last_modify_matricule` varchar(7) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


Thanks for any input!!










share|improve this question














I'm setting up a small signup form that should be inserting the data to an existing table, return the unique ID and insert that value to a secondary table.



Currently, I presume that the the first query is not running because the unique ID returned is 0.



I've gone over this small portion of code, that works on all my other developments and can't seem to figure out where it's blocking.



mysqli_query ($db_conx, "INSERT INTO Users
(first_name, last_name, dob, email, user_type, company, start_date, end_date, create_timestamp, last_modify_timestamp, create_matricule, pwd_hash)
VALUES
('$first_name','$last_name','$dob','$email','$user_type','$company','$start_date','$end_date','$create_timestamp','$create_timestamp','$create_matricule','$password_hash')");


//Now select this user to retreive the matricule

$matricule = mysqli_insert_id($db_conx);


$sql2 ="INSERT INTO Permissions (matricule) VALUES ('$matricule')";
$query2 = mysqli_query($db_conx, $sql2);

if(!$query){
echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
}

echo json_encode(['message'=>"Matricule ".$matricule." created", 'code'=>200]);

}


The console returns the following :



Object { message: "Matricule 0 created", code: 200 }
javascript.js:125:13
success javascript.js:126:13
ReferenceError: matricule is not defined[Learn More]


So therefore the creation to the second table works just fine but not the first.



My database is configured as follows:



CREATE TABLE `Users` (
`matricule` int(6) NOT NULL,
`first_name` varchar(35) NOT NULL,
`last_name` varchar(35) NOT NULL,
`dob` date NOT NULL,
`email` varchar(50) NOT NULL,
`user_type` varchar(3) NOT NULL,
`company` varchar(30) NOT NULL,
`start_date` date NOT NULL,
`end_date` date NOT NULL,
`pwd_hash` varchar(500) NOT NULL,
`pwd_reset_hash` varchar(100) NOT NULL,
`otp_token` varchar(6) NOT NULL,
`create_timestamp` datetime NOT NULL,
`create_matricule` varchar(7) NOT NULL,
`manager_matricule` varchar(7) NOT NULL,
`sq_1` varchar(2) NOT NULL,
`sa_1` varchar(50) NOT NULL,
`sq_2` varchar(2) NOT NULL,
`sa_2` varchar(50) NOT NULL,
`last_modify_timestamp` datetime NOT NULL,
`last_modify_matricule` varchar(7) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


Thanks for any input!!







php mysqli






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Jan 3 at 7:25









JAMES RYANJAMES RYAN

476




476













  • Note: do not concatenate strings to SQL queries. Use parameters. It will save you from a lot of headache

    – Sami Kuhmonen
    Jan 3 at 7:30



















  • Note: do not concatenate strings to SQL queries. Use parameters. It will save you from a lot of headache

    – Sami Kuhmonen
    Jan 3 at 7:30

















Note: do not concatenate strings to SQL queries. Use parameters. It will save you from a lot of headache

– Sami Kuhmonen
Jan 3 at 7:30





Note: do not concatenate strings to SQL queries. Use parameters. It will save you from a lot of headache

– Sami Kuhmonen
Jan 3 at 7:30












3 Answers
3






active

oldest

votes


















0














There is most probably an issued in the structure of you database or the JavaScript you haven't shared.






share|improve this answer































    3














    I think you mispelled some variable names.



    You are fetching $query2 :



    $query2 = mysqli_query($db_conx, $sql2);


    then checks $query :



    if(!$query){
    echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
    }





    share|improve this answer































      0














      First, you must make the quotation marks as follows.



      $sql="INSERT INTO Users (first_name) VALUES ('".$first_name."')";


      Or you can use prepared statements






      share|improve this answer



















      • 1





        stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

        – danny26b
        Jan 3 at 7:35








      • 1





        It also works the way he did it because the variable is inbetween the quotes.

        – WasteD
        Jan 3 at 7:36






      • 1





        It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

        – danny26b
        Jan 3 at 7:39












      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%2f54018011%2fmysqli-query-not-processing-correctly%23new-answer', 'question_page');
      }
      );

      Post as a guest















      Required, but never shown

























      3 Answers
      3






      active

      oldest

      votes








      3 Answers
      3






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      0














      There is most probably an issued in the structure of you database or the JavaScript you haven't shared.






      share|improve this answer




























        0














        There is most probably an issued in the structure of you database or the JavaScript you haven't shared.






        share|improve this answer


























          0












          0








          0







          There is most probably an issued in the structure of you database or the JavaScript you haven't shared.






          share|improve this answer













          There is most probably an issued in the structure of you database or the JavaScript you haven't shared.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Jan 6 at 6:45









          danny26bdanny26b

          947




          947

























              3














              I think you mispelled some variable names.



              You are fetching $query2 :



              $query2 = mysqli_query($db_conx, $sql2);


              then checks $query :



              if(!$query){
              echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
              }





              share|improve this answer




























                3














                I think you mispelled some variable names.



                You are fetching $query2 :



                $query2 = mysqli_query($db_conx, $sql2);


                then checks $query :



                if(!$query){
                echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
                }





                share|improve this answer


























                  3












                  3








                  3







                  I think you mispelled some variable names.



                  You are fetching $query2 :



                  $query2 = mysqli_query($db_conx, $sql2);


                  then checks $query :



                  if(!$query){
                  echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
                  }





                  share|improve this answer













                  I think you mispelled some variable names.



                  You are fetching $query2 :



                  $query2 = mysqli_query($db_conx, $sql2);


                  then checks $query :



                  if(!$query){
                  echo json_encode(['message'=>"Error : ". mysqli_error($db_conx), 'code'=>500]);
                  }






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Jan 3 at 7:29









                  jtouzyjtouzy

                  19617




                  19617























                      0














                      First, you must make the quotation marks as follows.



                      $sql="INSERT INTO Users (first_name) VALUES ('".$first_name."')";


                      Or you can use prepared statements






                      share|improve this answer



















                      • 1





                        stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

                        – danny26b
                        Jan 3 at 7:35








                      • 1





                        It also works the way he did it because the variable is inbetween the quotes.

                        – WasteD
                        Jan 3 at 7:36






                      • 1





                        It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

                        – danny26b
                        Jan 3 at 7:39
















                      0














                      First, you must make the quotation marks as follows.



                      $sql="INSERT INTO Users (first_name) VALUES ('".$first_name."')";


                      Or you can use prepared statements






                      share|improve this answer



















                      • 1





                        stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

                        – danny26b
                        Jan 3 at 7:35








                      • 1





                        It also works the way he did it because the variable is inbetween the quotes.

                        – WasteD
                        Jan 3 at 7:36






                      • 1





                        It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

                        – danny26b
                        Jan 3 at 7:39














                      0












                      0








                      0







                      First, you must make the quotation marks as follows.



                      $sql="INSERT INTO Users (first_name) VALUES ('".$first_name."')";


                      Or you can use prepared statements






                      share|improve this answer













                      First, you must make the quotation marks as follows.



                      $sql="INSERT INTO Users (first_name) VALUES ('".$first_name."')";


                      Or you can use prepared statements







                      share|improve this answer












                      share|improve this answer



                      share|improve this answer










                      answered Jan 3 at 7:32









                      manowar_manowarmanowar_manowar

                      8472926




                      8472926








                      • 1





                        stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

                        – danny26b
                        Jan 3 at 7:35








                      • 1





                        It also works the way he did it because the variable is inbetween the quotes.

                        – WasteD
                        Jan 3 at 7:36






                      • 1





                        It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

                        – danny26b
                        Jan 3 at 7:39














                      • 1





                        stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

                        – danny26b
                        Jan 3 at 7:35








                      • 1





                        It also works the way he did it because the variable is inbetween the quotes.

                        – WasteD
                        Jan 3 at 7:36






                      • 1





                        It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

                        – danny26b
                        Jan 3 at 7:39








                      1




                      1





                      stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

                      – danny26b
                      Jan 3 at 7:35







                      stackoverflow.com/questions/7137631/… The dots aren't necessary here though...

                      – danny26b
                      Jan 3 at 7:35






                      1




                      1





                      It also works the way he did it because the variable is inbetween the quotes.

                      – WasteD
                      Jan 3 at 7:36





                      It also works the way he did it because the variable is inbetween the quotes.

                      – WasteD
                      Jan 3 at 7:36




                      1




                      1





                      It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

                      – danny26b
                      Jan 3 at 7:39





                      It can work this way yes but it's not necessary... or not something that is causing an issue in this case.

                      – danny26b
                      Jan 3 at 7:39


















                      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%2f54018011%2fmysqli-query-not-processing-correctly%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