Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Где косяк в запросе к БД?

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Alex_dark74
Отправлено: 08 Марта, 2012 - 22:55:28
Post Id


Частый гость


Покинул форум
Сообщений всего: 210
Дата рег-ции: Янв. 2012  


Помог: 0 раз(а)




CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2. function add_manager($name)
  3. {
  4.         // Запрос.
  5.         mysql_query("INSERT INTO users (name_m) VALUES ($name)");
  6.                                                        
  7.         if (!$result)
  8.                 die(mysql_error());
  9.                
  10.         return true;
  11. }
  12.  


При вызове функции выводит
В данном случае $name = Anton
Unknown column 'Anton' in 'field list'
Не пойму в чем дело.Ведь "Anton" это информация которую нужно внести в БД а не искать такую колонку...
 
 Top
OrmaJever Модератор
Отправлено: 08 Марта, 2012 - 22:59:30
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




А это точно весь запрос?
Судя потому что переменая $result негде не обьявленна то вы точно что-то не дописали.
Скорее всего надо взять всё в кавычки, имена таблиц и полей в обратные (`), а значения а обычные (')
CODE (SQL):
скопировать код в буфер обмена
  1. INSERT INTO `users` (`name_m`) VALUES ('$name')


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
DlTA
Отправлено: 08 Марта, 2012 - 23:00:01
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2952
Дата рег-ции: Окт. 2010  


Помог: 53 раз(а)




а где написано что Anton это не назвние поля? если это значение то его берут в кавычки (')
а названия полей, таблиц, ... лучше брать в обратные кавычки (`)
 
 Top
Alex_dark74
Отправлено: 09 Марта, 2012 - 16:43:49
Post Id


Частый гость


Покинул форум
Сообщений всего: 210
Дата рег-ции: Янв. 2012  


Помог: 0 раз(а)




OrmaJever пишет:
Судя потому что переменая $result негде не обьявленна то вы точно что-то не дописали.


Переменная приходит через GET и попадает в эту функцию из другого файла
 
 Top
jovani
Отправлено: 09 Марта, 2012 - 23:12:04
Post Id



Новичок


Покинул форум
Сообщений всего: 32
Дата рег-ции: Март 2012  


Помог: 0 раз(а)




а если прописать так
CODE (htmlphp):
скопировать код в буфер обмена
  1. $result = mysql_query("INSERT INTO users (name_m) VALUES ($name)");
 
 Top
LIME
Отправлено: 09 Марта, 2012 - 23:17:31
Post Id


Активный участник


Покинул форум
Сообщений всего: 10732
Дата рег-ции: Нояб. 2010  


Помог: 322 раз(а)




выше аж 2 раза указали на ошибку
 
 Top
Alex_dark74
Отправлено: 12 Марта, 2012 - 11:58:58
Post Id


Частый гость


Покинул форум
Сообщений всего: 210
Дата рег-ции: Янв. 2012  


Помог: 0 раз(а)




И в новь та же беда, только теперь с
CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2.  
  3. $name = 'Anton';
  4. $id_user = 8;
  5.  
  6. function updte_manager ($name, $id_user) //Назначение фирмы менеджеру
  7. {
  8.         // Запрос.
  9.         $result = mysql_query("UPDATE users SET name_m = $name WHERE id_m = $id_user");
  10.                                                        
  11.         if (!$result)
  12.                 die(mysql_error());
  13. }
  14.  
  15. updte_manager ($name, $id_user)
  16.  
  17.  


Выводит : Unknown column 'Anton' in 'field list'
(Добавление)
Все ребята нашел.)))
Спасибо!
вот как нужно:
CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2. UPDATE `users` SET `name_m` = '$name' WHERE `id_m` = '$id_user'
  3.  
 
 Top
Maxi
Отправлено: 12 Марта, 2012 - 13:45:45
Post Id



Гость


Покинул форум
Сообщений всего: 107
Дата рег-ции: Июнь 2010  
Откуда: Kharkov, Ukraine


Помог: 0 раз(а)




"INSERT INTO `users` (`name_m`) VALUES (".$name.")"; // правда, что если писать так, то работает быстрее?

(Отредактировано автором: 12 Марта, 2012 - 13:46:03)

 
 Top
snikers987
Отправлено: 12 Марта, 2012 - 15:16:24
Post Id



Участник


Покинул форум
Сообщений всего: 1239
Дата рег-ции: Сент. 2011  
Откуда: Крым


Помог: 25 раз(а)




Maxi пишет:
"INSERT INTO `users` (`name_m`) VALUES (".$name.")"; // правда, что если писать так, то работает быстрее?


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


-----
Когда всматриваешься в тёмную бездну, учти, что кто-то может смотреть на тебя из неё...
 
My status
 Top
Bio man
Отправлено: 12 Марта, 2012 - 17:04:43
Post Id


Постоянный участник


Покинул форум
Сообщений всего: 2751
Дата рег-ции: Июль 2010  
Откуда: Даугавпилс, Латвия


Помог: 52 раз(а)




snikers987 пишет:
значения нужно брать в кавычки.
только строковые. тип INT, FLOAT и иже с ними не надо брать в кавычки
 
 Top
UNTRUSTED
Отправлено: 12 Марта, 2012 - 17:25:21
Post Id


Частый гость


Покинул форум
Сообщений всего: 255
Дата рег-ции: Март 2012  


Помог: 2 раз(а)




Да, я тоже помню как то затупил, переменную в кавычки не занес, на она, хоть ми была строковая состояла из чисел (вот такого вида xx-yy-zz, где x,y,z - числа - вообщем как дата можно сказать), так он это понимал как математическую и в итоге выдавал одно число... Долго помню искал куда остальные деютсяУлыбка) Радость Радость Радость
 
 Top
snikers987
Отправлено: 12 Марта, 2012 - 18:43:29
Post Id



Участник


Покинул форум
Сообщений всего: 1239
Дата рег-ции: Сент. 2011  
Откуда: Крым


Помог: 25 раз(а)




Bio man пишет:
snikers987 пишет:
значения нужно брать в кавычки.
только строковые. тип INT, FLOAT и иже с ними не надо брать в кавычки

Можно и брать, только это добавит работы бд, ошибки в этом точно не будет. Я конечно имел ввиду строковые значения, так как данный сабж о них.


-----
Когда всматриваешься в тёмную бездну, учти, что кто-то может смотреть на тебя из неё...
 
My status
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB