Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Выбор максимально популярного... 
V
    Опции темы
mladenez
Дата 25.12.2007, 14:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.7.2007

Репутация: нет
Всего: нет



У меня есть Таблица такого вида:

ID      Значение
1         1
2         1
3         1
4         2
5         2
6         3

Мне надо составить запрос таким образом чтобы выбралось самое популярное значение,в данном случае результатом будет '1'!
PM MAIL   Вверх
Sqlninja
Дата 25.12.2007, 15:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 353
Регистрация: 15.5.2006
Где: San Francisco, CA

Репутация: нет
Всего: 13



Код

select val
from   (select   val,
                 count (*) cnt
        from     x
        group by val)
where  cnt = (select max (cnt)
              from   (select   val,
                               count (*) cnt
                      from     x
                      group by val))


или

Код

select val
from   (select   val,
                 count (*) cnt
        from     x
        group by val
        order by cnt desc)
where  ROWNUM = 1;


Это сообщение отредактировал(а) Sqlninja - 25.12.2007, 15:55


--------------------
It's better to burn out than to fade away.
PM MAIL WWW ICQ   Вверх
mladenez
Дата 25.12.2007, 17:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.7.2007

Репутация: нет
Всего: нет



А что в этом случае есть 'cnt'?
PM MAIL   Вверх
skyboy
Дата 25.12.2007, 17:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 5
Всего: 260



mladenez, псевдоним для поля.

Добавлено через 11 секунд
точнее, для выражения.

Добавлено через 4 минуты
не знаю, как в общем виде(скорее всего - только так, как показал sqlninja), но для MySQL подойдет такой вариант:
Код

SELECT val, count (*) cnt
FROM x
GROUP BY val
ORDER BY cnt DESC
LIMIT 1

PM MAIL   Вверх
mladenez
Дата 25.12.2007, 17:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.7.2007

Репутация: нет
Всего: нет



СПАСИБО!!!Очень помогло!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1067 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.