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

Форум MySQL

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

 

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

вид форума:
Линейный форум Структурный форум

тема: Как задать имя столбца через переменную рнр?
 
 автор: Владимир55   (13.03.2009 в 19:58)   письмо автору
 
 

mysql_query ("INSERT INTO bot_knigi (str, `$namebot`) VALUES ('$str', '$time_s')");

Здесь имя столбца, в который надлежит сделать запись, я попытался задать через переменную $namebot`. Сервер этого не одобрил, хотя я перебрал все возможные варианты кавычек, а также и без них.

Что же здесь неверно?

Аналогичная проблема возникает с UPDATE, когда я пытаюсь задать имена столбцов через переменную рнр.

  Ответить  
 
 автор: Loki   (13.03.2009 в 20:31)   письмо автору
 
   для: Владимир55   (13.03.2009 в 19:58)
 

а если так?
<?mysql_query ("INSERT INTO bot_knigi (str, `".$namebot."`) VALUES ('$str', '$time_s')")

  Ответить  
 
 автор: Владимир55   (13.03.2009 в 21:07)   письмо автору
 
   для: Loki   (13.03.2009 в 20:31)
 

А так работает!

Но только именно так, как Вы написали - с двойными кавычками и с точками с обеих сторон. Какой же сложный и неочевидный синтаксис!

Спасибо!

  Ответить  
 
 автор: Loki   (13.03.2009 в 21:38)   письмо автору
 
   для: Владимир55   (13.03.2009 в 21:07)
 

>Какой же сложный и неочевидный синтаксис!
Только если не читать мануал. Ибо в мануале написано буквально следующее:
Если интерпретатор встречает знак доллара ($), он захватывает так много символов, сколько возможно, чтобы сформировать правильное имя переменной. Если вы хотите точно определить конец имени, заключайте имя переменной в фигурные скобки.

То есть в вашем случае php думал что переменная называется не $namebot, а $namebot` (с кавычкой на конце), а так как такой переменной нет, то вместо имени поля вставлялось пустое значение.

  Ответить  
Rambler's Top100
вверх

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