Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Количество уникальных значений полей.
 
 автор: Евгений Петров   (14.08.2005 в 13:42)   письмо автору
 
 

Помогите мне с SQL - запросом. Мне нужно вывести из базы данных все уникальные записи и количество каждой из таких записей. Т.е. например есть таблица с записями:
Один
Один
Один
Два
Два
Три
Четыре

надо вывести:
Один   | 3
Два    | 2
Три    | 1
Четыре | 1

   
 
 автор: cheops   (14.08.2005 в 14:11)   письмо автору
 
   для: Евгений Петров   (14.08.2005 в 13:42)
 

Такого рода запросы, выполняются при помощи комбинации одной из агрегатных функций (здесь это COUNT() - подсчёт числа строк) и конструкции GROUP BY
SELECT name, COUNT(name) 
FROM tbl
GROUP BY name;

   
 
 автор: Евгений Петров   (14.08.2005 в 14:26)   письмо автору
 
   для: cheops   (14.08.2005 в 14:11)
 

Спасибо!

   
 
 автор: Евгений Петров   (21.08.2005 в 22:19)   письмо автору
 
   для: Евгений Петров   (14.08.2005 в 14:26)
 

А ещё вопрос! Отсортировать эти данные по числу строк (т.е по COUNT())?

   
 
 автор: cheops   (22.08.2005 в 02:10)   письмо автору
 
   для: Евгений Петров   (21.08.2005 в 22:19)
 

Для этого, столбцу с COUNT(name) следует назначить псевдоним и сортировать по нему
SELECT name, COUNT(name) AS total
FROM tbl 
GROUP BY name
ORDER BY total;

   
 
 автор: Ziq   (22.08.2005 в 07:46)   письмо автору
 
   для: cheops   (22.08.2005 в 02:10)
 

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

SELECT DISTINCT COUNT(name), name AS total 
FROM tbl 
GROUP BY name 
ORDER BY total; 

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования