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 MAX не работает.

 PHP.SU

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


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

> Без описания
Dazar
Отправлено: 16 Августа, 2012 - 12:52:17
Post Id


Частый гость


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


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




Хоть убейте, ничего не выводит код
PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX('id') FROM users WHERE x='$x' ";
  2. $res = mysql_query($query) or die(mysql_error());
  3. while ($row = mysql_fetch_array($res)) {
  4. echo $row['id'];
  5. }

Хотя
PHP:
скопировать код в буфер обмена
  1. $query="SELECT id FROM users WHERE x='$x' ";
  2. $res = mysql_query($query) or die(mysql_error());
  3. while ($row = mysql_fetch_array($res)) {
  4. $id=$row['id'];
  5. echo "$id ";
  6. }

Выводит положенные 1 3 4 14 16
 
 Top
tuareg
Отправлено: 16 Августа, 2012 - 12:57:39
Post Id


Участник


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


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




PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX('id') FROM users WHERE x='$x' ";

Замените на
PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX(`id`) FROM users WHERE x='$x' ";

или
PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX(id) FROM users WHERE x='$x' ";
 
 Top
Dazar
Отправлено: 16 Августа, 2012 - 13:00:14
Post Id


Частый гость


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


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




Пробовал и с кавычками, и без, ваши тоже сейчас попробовал, никак Огорчение
 
 Top
tuareg
Отправлено: 16 Августа, 2012 - 13:01:26
Post Id


Участник


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


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




Выложи результат
PHP:
скопировать код в буфер обмена
  1. echo "SELECT MAX('id') FROM users WHERE x='$x' ";

(Добавление)
Еще как вариант если нет индекса по полю x
PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX(id) FROM users WHERE x='$x'  GROUP BY x";
 
 Top
Dazar
Отправлено: 16 Августа, 2012 - 13:06:06
Post Id


Частый гость


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


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




Эм.. Так и выводит:
SELECT MAX('id') FROM users WHERE x='1'
Такой код:
PHP:
скопировать код в буфер обмена
  1.  
  2. $query="SELECT MAX('id') FROM users WHERE x='$x' ";
  3. $res = mysql_query($query) or die(mysql_error());
  4. echo $res;
  5.  

Выводит Resource id #5

(Отредактировано автором: 16 Августа, 2012 - 13:06:30)

 
 Top
tuareg
Отправлено: 16 Августа, 2012 - 13:09:52
Post Id


Участник


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


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




Вот это должно работать
PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX(id) FROM users WHERE x='$x'  GROUP BY x";

Да он и без GROUP BY работает.
PHP:
скопировать код в буфер обмена
  1. $query="SELECT MAX(id) FROM users WHERE x='$x'";

(Отредактировано автором: 16 Августа, 2012 - 13:12:27)

 
 Top
Dazar
Отправлено: 16 Августа, 2012 - 13:16:48
Post Id


Частый гость


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


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




Нет, тоже нет.
Чуть попозже выложу в интернете на бесплатном хостинге, чтобы не быть голословным.
(Добавление)
В конце концов, гори оно всё огнём:
$query="SELECT id FROM users WHERE x='$x' ORDER BY id DESC LIMIT 1";
 
 Top
EuGen Администратор
Отправлено: 16 Августа, 2012 - 13:21:07
Post Id


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


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


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




Dazar пишет:
$query="SELECT id

- и обращаетесь $row['id']. Работает.
Dazar пишет:
$query="SELECT MAX('id')

- но обращаетесь все так же $row['id']. Не работает. По-моему, ответ очевиден.
Выбирайте SELECT MAX(`id`) AS max_id и обращайтесь $row['max_id']


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Dazar
Отправлено: 16 Августа, 2012 - 14:39:44
Post Id


Частый гость


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


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




Вот, действительно, всё работает, спасибо.
 
 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