2016-07-28 46 views
-1

任何人都可以看到下面的代碼有什麼問題。 當我使用HTML表單提交數據時,我收到預期的確認以確認註冊。但是,當我檢查數據庫時,它不在那裏!表單數據不發佈到數據庫

我已經檢查了名稱分別輸入相同的名稱是否正確,並確認數據庫連接成功,與數據庫中的列ECT的名字一起...

任何幫助將非常感激。

<?php 

    if (isset($_POST['carrierinsert'])) { 

    $acc = $_POST['acc']; 


    $sql = "SELECT cariers.acc FROM cariers WHERE cariers.acc ='$acc'"; 
    $result = $db->query($sql); 

    if($result->num_rows > 0) { 

     echo "<font color='red'>Carrier Already exits</font>"; 


    $sql = "INSERT INTO cariers (`reg`, `acc`, `accstatus`, `carramid`, `carrfloor`, `pay`, `comms`) 
    VALUES ('".$db->real_escape_string($_POST['reg'])."', 
      '".$db->real_escape_string($_POST['acc'])."', 
      '".$db->real_escape_string($_POST['accstatus'])."', 
      '".$db->real_escape_string($_POST['carramid'])."',  
      '".$db->real_escape_string($_POST['carrfloor'])."', 
      '".$db->real_escape_string($_POST['pay'])."',   
      '".$db->real_escape_string($_POST['comms'])."')"; 


     $insert = $db->query($sql); 

        echo "<font color='red'>Carrier Inserted</font>"; 

     } 
     } 
     ?> 


       <h1>Add New</h1> 
       <hr> 




      <form method="post" action=""> Carrier<br /> 




      <input name="reg" type="text" required="required" value=""> 
      <br /><br /> 




      Number<br /> 
      <input name="acc" type="text" required="required" value=""> 
      <br /><br /> 



      Status<br /> 
      <input name="accstatus" type="text" required="required" value=""> 





      Floor<br /> 
      <select name="carrfloor" id="carrfloor"> 
      <option name="carrfloor" Value="1">1</option> 
      <option name="carrfloor" Value="2">2</option> 
      </select> 
      <br /><br /> 




      Pay<br /> 
      <select name="pay" id="pay"> 
      <option selected="selected" name="pay" Value="0">N/A</option> 
      <option name="pay" Value="1">1%</option> 
      <option name="pay" Value="1.25">1.25%</option> 
      <option name="pay" Value="1.5">1.5%</option> 
      <option name="pay" Value="1.75">1.75%</option> 
      <option name="pay" Value="2">2%</option> 
      <option name="pay" Value="2.25">2.25%</option> 
      <option name="pay" Value="2.50">2.50%</option> 
      <option name="pay" Value="3.00">3%</option> 
      </select> 
      <br /><br /> 



      Additional Charge<br /> 
      <select name="comms" id="comms"> 
      <option name="comms" selected ="selected" Value="Fees">Yes</option> 
      <option name="comms" Value="No Fees">No</option> 
      </select> 
      <br /><br /> 



      Manager<br /> 
      <select name="carramid" id="carramid"> 
      <option name="carramid" Value="Yes">Yes</option> 
      <option name="carramid" Value="No">No</option> 
      </select> 
      <br /><br /> 


      <br /><br /> 
      <input type="submit" class="btn" name="carrierinsert" value="Save" /> 


      </form> 
+2

將一個引號切換爲在sql變量中加一。 __'__ - > __「__ –

+1

好吧,顯然,你失敗了,你並沒有檢查錯誤;你期望什麼,*魔術?* –

+0

更不用說你忘了本應發佈的HTML表單所以,我們怎麼知道這不是也在這裏失敗? –

回答

0
$sql = "INSERT INTO cariers (reg, acc, accstatus, carramid, carrfloor, pay, comms) 
     VALUES ('".{$db->real_escape_string($_POST['reg'])}."', 
       '".{$db->real_escape_string($_POST['acc'])}."', 
       '".{$db->real_escape_string($_POST['accstatus'])}."', 
       '".{$db->real_escape_string($_POST['carramid'])}."',  
       '".{$db->real_escape_string($_POST['carrfloor'])}."', 
       '".{$db->real_escape_string($_POST['pay'])}."',   
       '".{$db->real_escape_string($_POST['comms'])}."')"; 

UPDATE

$a = 15; 

    echo 'this will not write 15: $a' 
     .PHP_EOL. 
     "this will write 15: $a" 
     .PHP_EOL. 
     "but i can escape a variable anyways. i dont need to change quotes".$a.' dot (.) is the add method for strings' 
     ; 
+2

你能解釋你在這裏做了什麼嗎 –

+0

......我猜不是 –

+0

我根據Mehmet它的說法 - 在-Parse錯誤:語法錯誤,意外'在第19行這是VALUES('「。{$ db-> real_escape_string($ _ POST ['reg'])}'', – scarlet

0

試試這個:

$sql = "INSERT INTO cariers (`reg`, `acc`, `accstatus`, `carramid`, `carrfloor`, `pay`, `comms`) 
     VALUES ('".$db->real_escape_string($_POST['reg'])."', 
       '".$db->real_escape_string($_POST['acc'])."', 
       '".$db->real_escape_string($_POST['accstatus'])."', 
       '".$db->real_escape_string($_POST['carramid'])."',  
       '".$db->real_escape_string($_POST['carrfloor'])."', 
       '".$db->real_escape_string($_POST['pay'])."',   
       '".$db->real_escape_string($_POST['comms'])."')"; 

EDITTED: 試試這個代碼

<?php 
    if (isset($_POST['carrierinsert'])) { 
     $acc = $_POST['acc']; 
     $sql = "SELECT cariers.acc FROM cariers WHERE cariers.acc ='$acc'"; 
     $result = $db->query($sql); 

     if($result->num_rows > 0) { 
      echo "<font color='red'>Carrier Already exits</font>"; 
     }else{ 

      $sql = "INSERT INTO cariers (`reg`, `acc`, `accstatus`, `carramid`, `carrfloor`, `pay`, `comms`) VALUES ('".$db->real_escape_string($_POST['reg'])."', '".$db->real_escape_string($_POST['acc'])."','".$db->real_escape_string($_POST['accstatus'])."','".$db->real_escape_string($_POST['carramid'])."', '".$db->real_escape_string($_POST['carrfloor'])."','".$db->real_escape_string($_POST['pay'])."','".$db->real_escape_string($_POST['comms'])."')"; 
      $insert = $db->query($sql); 
      echo "<font color='red'>Carrier Inserted</font>"; 
      } 
     } 
?> 


<h1>Add New</h1> 
<hr> 
<form method="post" action=""> Carrier<br /> 
     <input name="reg" type="text" required="required" value=""> 
     <br /><br /> 
    Number<br /> 
     <input name="acc" type="text" required="required" value=""> 
     <br /><br /> 
    Status<br /> 
     <input name="accstatus" type="text" required="required" value=""> 
    Floor<br /> 
     <select name="carrfloor" id="carrfloor"> 
      <option value="1">1</option> 
      <option value="2">2</option> 
     </select> 
     <br /><br /> 
    Pay<br /> 
     <select name="pay" id="pay"> 
      <option selected="selected" value="0">N/A</option> 
      <option value="1">1%</option> 
      <option value="1.25">1.25%</option> 
      <option value="1.5">1.5%</option> 
      <option value="1.75">1.75%</option> 
      <option value="2">2%</option> 
      <option value="2.25">2.25%</option> 
      <option value="2.50">2.50%</option> 
      <option value="3.00">3%</option> 
     </select> 
    <br /><br /> 
    Additional Charge<br /> 
     <select name="comms" id="comms"> 
      <option selected ="selected" value="Fees">Yes</option> 
      <option value="No Fees">No</option> 
     </select> 
     <br /><br /> 
    Manager<br /> 
     <select name="carramid" id="carramid"> 
      <option value="Yes">Yes</option> 
      <option value="No">No</option> 
     </select> 
     <br /><br /> 
     <br /><br /> 
    <input type="submit" class="btn" name="carrierinsert" value="Save" /> 
</form> 
+2

他們爲什麼要*試試這個*?啓迪我們;-) –

+1

downvote你剛剛得到,不是我的。只是讓你知道。 –

+0

對不起,我忘了添加雙引號。我更新查詢請現在看到 –