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 :: SELECT в INSERT

 PHP.SU

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


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

> Описание: Incorrect integer value...
Viper
Отправлено: 15 Февраля, 2013 - 11:26:48
Post Id



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


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


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




Собстно непонятка какая-то происходит.

Есть запрос вида
CODE (SQL):
скопировать код в буфер обмена
  1. INSERT INTO `bdp3c_webcon_rel_subscribers`
  2.             (`cid`, `sid`, `ordering`, `custom_subscr_params`, `is_active`)
  3. VALUES ('2', '15', '(SELECT MAX(`ordering`) FROM `bdp3c_webcon_rel_subscribers` WHERE `cid` = 2)', '{}', '0');


Строку то мускуль вставляет, но вот говорит
Цитата:
Incorrect integer value: '(SELECT MAX(`ordering`) FROM `bdp3c_webcon_rel_subscribers` WHERE `cid` = 2)' for column 'ordering' at row 1

С чем это связано?


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
EuGen Администратор
Отправлено: 15 Февраля, 2013 - 11:35:28
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




С тем, что вложенный запрос следует без кавычек в подобном синтаксисе указывать.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Viper
Отправлено: 15 Февраля, 2013 - 12:12:37
Post Id



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


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


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




EuGen пишет:
без кавычек

You can't specify target table 'bdp3c_webcon_rel_subscribers' for update in FROM clause


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
EuGen Администратор
Отправлено: 15 Февраля, 2013 - 12:24:24
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




А, ну да, верно. Я не заметил, что Вы пытаетесь вставить данные с выборкой из одной и той же таблицы. Тогда, как вариант,
CODE (SQL):
скопировать код в буфер обмена
  1. SET @max=(SELECT MAX(`ordering`) FROM `bdp3c_webcon_rel_subscribers` WHERE `cid` = 2);
  2. INSERT INTO `bdp3c_webcon_rel_subscribers`
  3.                 (`cid`, `sid`, `ordering`, `custom_subscr_params`, `is_active`)
  4.     VALUES ('2', '15', @max, '{}', '0');


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Viper
Отправлено: 15 Февраля, 2013 - 13:09:25
Post Id



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


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


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




Все же прийдется на 2 отдельных запроса разбить. Ибо если SELECT возвращает null, то ошибка.


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
EuGen Администратор
Отправлено: 15 Февраля, 2013 - 17:19:52
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




Viper
Тогда IFNULL


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
tuareg
Отправлено: 15 Февраля, 2013 - 21:17:46
Post Id


Участник


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


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




Можно и одним.
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. INSERT INTO `bdp3c_webcon_rel_subscribers`
  3.             (`cid`, `sid`, `ordering`, `custom_subscr_params`, `is_active`)
  4. VALUES ('2', '15', '(SELECT IFNULL(MAX(`ordering`),0) FROM `bdp3c_webcon_rel_subscribers` As t WHERE `cid` = 2)', '{}', '0');
  5.  
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB