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

Форум MySQL

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

 

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

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

тема: Не заносит в базу

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

 
 автор: Trianon   (12.06.2009 в 14:57)   письмо автору
 
   для: nikita2206   (12.06.2009 в 14:20)
 

Да нет вовсе.
Наплыв этого шаблона if(isset($_POST['name'])) $name = $_POST['name']; последнее время участился.
Хотелось ответить именно такими словами.
Правда вместо них лезли другие "Что ж ты делаешь, баран?! Ты же создаешь код, который в половине случаев оставляет переменную не инициализированной! О какой надежности после этого можно говорить?!" . А они здесь не приветствуются.

На всякий случай акцентирую, вышеприведенное - не Слонику персонально. Кодеров с таким подходом здесь десять на дюжину.

  Ответить  
 
 автор: nikita2206   (12.06.2009 в 14:20)   письмо автору
 
   для: Trianon   (12.06.2009 в 10:47)
 

ммм сарказм

  Ответить  
 
 автор: Trianon   (12.06.2009 в 10:50)   письмо автору
 
   для: Slo_Nik   (12.06.2009 в 00:22)
 

Таким подходом Вы, фактически, низводите методы кодирования на php5 до уровня методов кодирования на php3. Со всеми вытекающими оргвыводами в плане надежности кода.

И только потому, что когда-то напоролись на старый (с лет пять не апгрейдившимся софтом) хостинг.

  Ответить  
 
 автор: Trianon   (12.06.2009 в 10:47)   письмо автору
 
   для: nikita2206   (12.06.2009 в 00:39)
 

>> if(isset($_POST['name'])) $name = $_POST['name'];
>... проверяем существует ли элемент массива $_POST под ключём name, далее если существует то создаётся переменная $name, но заметте, если не существует, то $name не создаётся, если есть логика, то несложно понять, что это действие не имеет ни какой практической пользы, разве что, переменная теперь с более коротким именем…
>тогда, я думаю, было бы гораздо разумней написать, например, так:
>$name = @$_POST['name'];

Золотая мысль.
Почему-то большинству здесь активно присутствующих в голову не приходит.

  Ответить  
 
 автор: nikita2206   (12.06.2009 в 00:42)   письмо автору
 
   для: scva   (12.06.2009 в 00:25)
 

нет не так, и еще, используйте по возможности одинарные кавычки вместо двойных и соответственно конкатенацию…
вот так правильно:
<?
mysql
('INSERT INTO `order` ( `id` , `name` )VALUES ('.$id.', "'.$_POST['soname'].'")');

P.S. хорошо хоть то, что используете наклонные кавычки в mysql)

  Ответить  
 
 автор: nikita2206   (12.06.2009 в 00:39)   письмо автору
 
   для: Slo_Nik   (12.06.2009 в 00:22)
 

я думаю вы заблуждаетесь и не нашли реальной причины проблемы…
просто смотрите что сдесь делается: сначала проверяем существует ли элемент массива $_POST под ключём name, далее если существует то создаётся переменная $name, но заметте, если не существует, то $name не создаётся, если есть логика, то несложно понять, что это действие не имеет ни какой практической пользы, разве что, переменная теперь с более коротким именем…
тогда, я думаю, было бы гораздо разумней написать, например, так:
$name = @$_POST['name'];
или, если уж заняться нечем, то так:
$name = array_key_exist($_POST, 'name') ? $_POST['name'] : exit('Some variables was not submited to this script.');

  Ответить  
 
 автор: Slo_Nik   (12.06.2009 в 00:35)   письмо автору
 
   для: scva   (12.06.2009 в 00:25)
 

попробуй так сделать и тебе выдаст ошибку

  Ответить  
 
 автор: scva   (12.06.2009 в 00:25)   письмо автору
 
   для: nikita2206   (12.06.2009 в 00:14)
 

INSERT INTO `order` ( `id` , `name` )VALUES ('$id','$_POST['soname']') так что ли

  Ответить  
 
 автор: Slo_Nik   (12.06.2009 в 00:22)   письмо автору
 
   для: nikita2206   (12.06.2009 в 00:14)
 

легче конечно использовать $_POST['name'], но есть возможность, что на некоторых хостах может не сработать.
а вот

<?php 
if(isset($_POST['name'])) $name $_POST['name'];
?>

сработает всегда.
я с такой фигнёй раз столкнулся.

  Ответить  
 
 автор: Slo_Nik   (12.06.2009 в 00:18)   письмо автору
 
   для: scva   (12.06.2009 в 00:09)
 

я тебе привёл пример запроса.
определить переменные естественно надо до запроса.
в начале ты используешь короткие теги "<? ?>", а потом "<?php ?>", сделай одинаково

  Ответить  

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

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

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