2014-10-24 4 views
0

У меня есть программа с MySQL вставки запроса:Ошибка при вставке в базу данных SQL с помощью PHP

 $sql = "INSERT INTO people (person_id, name, username, password, email, salt) 
       VALUES ($person_id, $name, $username, $password, $email, $salt)"; 
     if ($con->query($sql) === TRUE) { 
      successful(); 
     } else { 
      unsuccessful("Error: " . $sql . "<br>" . $con->error); 
     } 

Когда я запускаю код, я получаю эту ошибку:

Error: INSERT INTO people (person_id, name, username, password, email, salt) VALUES (2, Tom Jack, tjack95, 8a01fc598a676a249c5844bd3baf4f4d83cecdf2, [email protected], eb694539989fda2e17f79e70fb306f8911c3dee5) 
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Jack, tjack95, 8a01fc598a676a249c5844bd3baf4f4d83cecdf2, [email protected], eb69' at line 2 

Вставка SQL выглядит полностью Прекрасно. В чем проблема?

+2

Либо процитировать ваши строковые значения или лучше использовать подготовленные заявления –

ответ

4

Вы упускаете кавычки ваших строковых значений:

$sql = "INSERT INTO people (person_id, name, username, password, email, salt) 
      VALUES ($person_id, '$name', '$username', '$password', '$email', '$salt')"; 
+0

ДА !!! Огромное спасибо. Я приму свой ответ, когда смогу через 11 минут. – kabeersvohra

+0

У вас был [реферал ...] (http://stackoverflow.com/q/28483844/) ;-) –

Смежные вопросы