Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: не записваются данные в БД

Сообщения:  [1-10]    [11-20]  [21-21] 

 
 автор: cheops   (12.12.2011 в 20:52)   письмо автору
 
   для: usa   (12.12.2011 в 20:10)
 

Внешне вроде да, но лучше проверить, обязательно обработав запрос на успешность выполнения, в случае неудачи выводить отчет mysql_error(), чтобы выяснить, где проблема.

  Ответить  
 
 автор: usa   (12.12.2011 в 20:10)   письмо автору
 
   для: Sfinks   (07.12.2011 в 18:47)
 

вот поставил кавычки
$result = mysql_query ("UPDATE pu SET title='$title', licence='$licence', 
accreditation='$accreditation', address='$address', tel='$tel', fax='$fax', 
site='$site', email='$email', full_name='$full_name', short_name='$short_name' 
WHERE id_pu=" . mysql_real_escape_string($id_pu) . "");

Теперь все ОК в запросе?

  Ответить  
 
 автор: Sfinks   (07.12.2011 в 18:47)   письмо автору
 
   для: usa   (07.12.2011 в 16:15)
 

>Как можно оставлять поле не заполненным?
2 варианта.
Первый - в свойствах таблицы полям, которые можно не заполнять, нужно присвоить значения по умолчанию. Тогда при добавлении записи поля значения для которых не переданы будут заполняться значениями по умолчанию
Второй - Пусть из формы приходят и не все поля, но во время проверки правильности введенных данных, переменным, значения для которых не установлены, присваивать ничтожные (а может и значимые), но адекватные данные. Т.е., например, 0 для поля integer, "" для string и т.д. Но делать все это до отправки запроса в БД.

  Ответить  
 
 автор: Valick   (07.12.2011 в 16:56)   письмо автору
 
   для: usa   (07.12.2011 в 16:47)
 

mysql_real_escape_string
эксейпирование и магические кавычки - это как раз то что не грех спросить у гугла :)
поверьте лучше чем гугл или хорошая книга, я вам не смогу рассказать в рамках форума.
учитесь разделять информацию и выхватывать самую суть
___
в соседней теме отредактируйте сообщение что бы оно помещалось в окно браузера и не растягивало его, а то читать не удобно

  Ответить  
 
 автор: usa   (07.12.2011 в 16:47)   письмо автору
 
   для: Valick   (07.12.2011 в 16:39)
 

я решил это просто - написал, что все поля обязательны к заполнению.

а вот "и кстати после проверки валидности данных не мешало бы применять эскейпирование :))"
Можно поподробнее?

  Ответить  
 
 автор: Valick   (07.12.2011 в 16:39)   письмо автору
 
   для: usa   (07.12.2011 в 16:15)
 

естетсвенно записи не будет, так как запрос станет некорректным
его нужно собирать в соответствии с теми полями которые присутствуют
именно при проверке данных переданных из формы нужно "по кусочку" собирать запрос
___
и кстати после проверки валидности данных не мешало бы применять эскейпирование :))
на магические кавычки лучше не расчитывать

  Ответить  
 
 автор: usa   (07.12.2011 в 16:15)   письмо автору
 
   для: Valick   (07.12.2011 в 16:00)
 

заработало.
Только как быть если поле остается пустым, то запись не производится.
Как можно оставлять поле не заполненным?

  Ответить  
 
 автор: Valick   (07.12.2011 в 16:00)   письмо автору
 
   для: usa   (07.12.2011 в 15:54)
 

WHERE id_pu='$id_pu' -> WHERE id_pu=$id_pu
if ($result == 'true') -> ...

  Ответить  
 
 автор: usa   (07.12.2011 в 15:54)   письмо автору
 
   для: Valick   (07.12.2011 в 15:38)
 

переписал
<?php 
if (isset($title) && isset($licence) && isset($accreditation) && isset($address
&& isset(
$tel) && isset($fax) && isset($site) && isset($email) && isset($full_name
&& isset(
$short_name)&& isset($id_pu))
{
/*Здесь мы пишем, что можно заносить информацию в базу*/

$result mysql_query ("UPDATE pu SET title='$title', licence='$licence', 
accreditation='
$accreditation', address='$address', tel='$tel', 
fax='
$fax', site='$site', email='$email', full_name='$full_name', short_name='$short_name
WHERE id_pu='
$id_pu'");
if (
$result == 'true') {echo "<p>Ваша рубрика обновлена!</p>";}
else {echo 
"<p>Ваша рубрика не обновлена!</p>";}
}          
else 
{
echo 
"<p>Вы ввели не всю информацию, поэтому рубрика не может быть добавлена в базу</p>";
}
?>

Все равно тот же результат. Ваш ПУ не добавлен!
Про магические кавычки не знаю

  Ответить  
 
 автор: Valick   (07.12.2011 в 15:38)   письмо автору
 
   для: usa   (07.12.2011 в 15:32)
 

нет)
нужно использовать UPDATE вместо INSERT
вы же редактируете строку (о чем собственно нужно было сообщить в самом начале)
а не вставляете новую строку
хотя по идее новая строка должна вставиться если запрос корректный
кстати магические кавычки включены?

  Ответить  

Сообщения:  [1-10]    [11-20]  [21-21] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования