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 :: Не работает UPDATE в PDO

 PHP.SU

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


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

> Без описания
razorg1991
Отправлено: 23 Сентября, 2014 - 19:23:26
Post Id


Частый гость


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


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




Вроде делаю по инструкции

PHP:
скопировать код в буфер обмена
  1.  
  2. class Database {
  3. static function updateDownloadSearchlist($namelist) {
  4.         try{
  5.             $db = new PDO("sqlite:database/database.db");
  6.             $sql = 'UPDATE searchlist SET download = "download" WHERE namelist = :namelist';
  7.             $st = $db->prepare($sql);
  8.             $st->bindParam(':namelist', $namelist);
  9.             $st->execute();
  10.         }
  11.         catch(PDOException $e) {  
  12.                 echo $e->getMessage();  
  13.             }
  14. }
  15.  


Но не обновляются поля Не понял Главное SELECT и INSERT работают. А вот UPDATE почему-то нет (((
Единственное, что поле namelist в базе имеет DEFAULT значение, но вроде для SQL это не очень важно и его можно спокойно переопределять.
 
 Top
Мелкий Супермодератор
Отправлено: 23 Сентября, 2014 - 19:40:01
Post Id



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


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


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




Проверьте, что вы в метод передаёте. Не что вы думаете, что передаёте, а что передаёте на самом деле.


-----
PostgreSQL DBA
 
 Top
razorg1991
Отправлено: 23 Сентября, 2014 - 20:14:57
Post Id


Частый гость


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


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




Мелкий пишет:
Проверьте, что вы в метод передаёте. Не что вы думаете, что передаёте, а что передаёте на самом деле.

Смотрю прямо в методе куда передал переменную


Выдает string(10) "htc one 21"
В таблице в принципе поле имеет тип TEXT, скопировал: htc one 21
Т.е. никаких даже лишних пробелов нет.
Куда копать дальше?

Щас переписал обновление по id и сделал еще приведение типов, одни хрен не работает! Что за бред?

PHP:
скопировать код в буфер обмена
  1.  
  2. static function updateDownloadSearchlist($check) {
  3.         settype($check, "integer");
  4.         var_dump($check);
  5.         try{
  6.             $db = new PDO("sqlite:database/database.db");
  7.             $sql = 'UPDATE searchlist SET download = "download" WHERE id = :id';
  8.             $st = $db->prepare($sql);
  9.             $st->bindParam(':id', $check);
  10.             $st->execute();
  11.         }
  12.         catch(PDOException $e) {  
  13.                 echo $e->getMessage();  
  14.             }
  15.        }
  16.  

(Отредактировано автором: 23 Сентября, 2014 - 22:23:59)

 
 Top
razorg1991
Отправлено: 23 Сентября, 2014 - 22:59:27
Post Id


Частый гость


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


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




Разобрался! РЕШЕНО! Радость

Короче PDO напрочь отказывается напрямую заносить данные через запрос

CODE (SQL):
скопировать код в буфер обмена
  1. UPDATE searchlist SET download = "download" WHERE id = :id


Любое значение НЕОБХОДИМО БИНДИТЬ, причем биндить ТОЛЬКО ЧЕРЕЗ ПЕРЕМЕННУЮ, иначе так он тоже не работает!
Уж сильно намудрили с безопасностью запросов.
ЕДИНСТВЕННО ПРАВИЛЬНЫЙ ВАРИАНТ ТАКОЙ:

PHP:
скопировать код в буфер обмена
  1.  
  2. static function updateDownloadSearchlist($check) {
  3.         try{
  4.             $db = new PDO("sqlite:database/database.db");
  5.             $sql = 'UPDATE searchlist SET download = :download WHERE id = :id';
  6.             $st = $db->prepare($sql);
  7.             $st->bindParam(':id', $check);
  8.             $download = 'download';
  9.             $st->bindParam(':download', $download);
  10.             $st->execute();
  11.         }
  12.         catch(PDOException $e) {  
  13.                 echo $e->getMessage();  
  14.             }
  15.        }
  16.  
 
 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