Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967

Вывод самого активного абонента и количество звонков от этого абонента за указанный период времени

10.02.2015, 09:04. Показов 1332. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.

Есть таблица с абонентами и звонками (id, from, date, ....). from - это номер абонента.
Необходимо получить самого активного абонента за указанный период времени и количество звонков от него.
Запрос, который я смог написать, выглядит так
SQL
1
2
3
4
5
6
7
8
9
10
11
12
SELECT `from`, COUNT(`from`)
FROM `records`
WHERE `date` BETWEEN 1422910800 AND 1423515600
GROUP BY `from`
HAVING COUNT(`from`) = (
    SELECT MAX (`cnt`)
    FROM (
        SELECT `from`, COUNT(`from`) `cnt`
        FROM `records`
        GROUP BY `from`
    )
)
Но он ничего не находит.. Если убрать упоминание о периоде времени - то все работает на ура:
SQL
1
2
3
4
5
6
7
8
9
10
11
SELECT `from`, COUNT(`from`)
FROM `records`
GROUP BY `from`
HAVING COUNT(`from`) = (
    SELECT MAX (`cnt`)
    FROM (
        SELECT `from`, COUNT(`from`) `cnt`
        FROM `records`
        GROUP BY `from`
    )
)
Но как добавить поиск в определенный период времени?

БД SQLite.

З.Ы. Возможно, есть какой-то другой, лучший способ (а главное, работоспособный) ?

Заранее спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.02.2015, 09:04
Ответы с готовыми решениями:

Программа, находящая общую продолжительность звонков для каждого абонента
Помогите решить задачу, не могу ничего придумать, в C# новичок В текстовом файле записана информация о продолжительности телефонных...

Программа, находящая общую продолжительность звонков для каждого абонента
Не имею понятия, как это решить, помогите пожалуйста В текстовом файле записана информация о продолжительности телефонных звонков....

В таблице распечатке телефонных вызовов по номеру абонента определить число его исходящих звонков
Добрый вечер! Вопрос жизни и смерти! Не могу справиться с макросом. Нужно в таблице распечатке телефонных вызовов по номеру абонента...

8
Почетный модератор
Эксперт по компьютерным сетямЭксперт Windows
 Аватар для magirus
28049 / 15785 / 983
Регистрация: 15.09.2009
Сообщений: 67,752
Записей в блоге: 78
10.02.2015, 09:50
Спросил коллегу... к сожалению он не помнит логина от форума, поэтому поработаю испорченным телефоном...
Цитата Сообщение от KOPOJI Посмотреть сообщение
WHERE `date` BETWEEN 1422910800 AND 1423515600
спрашивает какой формат имеет "date" его смущает числовое значение... "1422910800"
1
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
10.02.2015, 09:55  [ТС]
UNIX_TIMESTAMP. По сути, это не важно - есть возможность поменять на любой другой, хоть DATETIME (там дата + время). Просто, повторюсь, это SQLite, и типа даты как такового там нет.
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
10.02.2015, 10:31
а что покажет
SQL
1
2
3
4
5
SELECT COUNT(`from`)
FROM `records`
WHERE 1=1
AND `date`>=1422910800 
AND `date`<=1423515600
Добавлено через 2 минуты
Цитата Сообщение от KOPOJI Посмотреть сообщение
типа даты как такового там нет.
SAP хранит как число 20150210. И ничего, на клиенте все можно распарсить. Сиквел сервер даже кастовать такое умеет

Добавлено через 7 минут
и да, не знаю как SQLite, сиквел сервер не любит NULL в BETWEEN .. AND
1
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
10.02.2015, 10:38
KOPOJI,

SQL
1
2
3
4
5
        SELECT TOP(1) `from`, COUNT(`from`) 'cnt'
        FROM `records`
        WHERE `date` BETWEEN 1422910800 AND 1423515600
        GROUP BY `from`
        ORDER BY 'cnt' DESC
не знаю есть ли тут аналог TOP , или LIMIT
1
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
10.02.2015, 11:02
Цитата Сообщение от KOPOJI Посмотреть сообщение
Необходимо получить самого активного абонента за указанный период времени и количество звонков от него
Цитата Сообщение от KOPOJI Посмотреть сообщение
SQL
1
2
3
4
5
6
SELECT MAX (`cnt`)
     FROM (
     SELECT `from`, COUNT(`from`) `cnt`
     FROM `records`
     GROUP BY `from`
     )
У тебя поиск Максимального значение ведётся без периода.
Цитата Сообщение от Metall_Version Посмотреть сообщение
SELECT TOP(1)
А вот тут подвох. Если их будет несколько?

Добавлено через 1 минуту
SQL
1
2
3
4
5
SELECT `from`, COUNT(`from`)
FROM `records`
WHERE `date` BETWEEN 1422910800 AND 1423515600
GROUP BY `from`
HAVING COUNT(`from`) = (SELECT COUNT(`from`) FROM `records` WHERE `date` BETWEEN 1422910800 AND 1423515600 GROUP BY `from` ORDER BY 1 DESC LIMIT 1)
1
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
10.02.2015, 11:21
Цитата Сообщение от Bit_Man Посмотреть сообщение
А вот тут подвох. Если их будет несколько?
в условии по поводу этого ни слова,
я бы писал так
SQL
1
SELECT TOP(1) WITH ties `from`, COUNT(`from`) 'cnt'
но это t-sql, какие возможности есть в лайте я не знаю.
1
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
10.02.2015, 14:34  [ТС]
Цитата Сообщение от pincet Посмотреть сообщение
а что покажет
то, что и должен 322 записи
Цитата Сообщение от Metall_Version Посмотреть сообщение
SELECT TOP(1)
Ошибка в запросе; no such function: TOP
Unable to execute statement
Цитата Сообщение от Bit_Man Посмотреть сообщение
SQL
1
2
3
4
5
SELECT `from`, COUNT(`from`)
FROM `records`
WHERE `date` BETWEEN 1422910800 AND 1423515600
GROUP BY `from`
HAVING COUNT(`from`) = (SELECT COUNT(`from`) FROM `records` WHERE `date` BETWEEN 1422910800 AND 1423515600 GROUP BY `from` ORDER BY 1 DESC LIMIT 1)
А вот это работает, спасибо
0
10.02.2015, 15:55

Не по теме:


шишкин лес, с чего бы ему не работать. Тщательнее нужно. В первую очередь всем. :)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.02.2015, 15:55
Помогаю со студенческими работами здесь

Отчет за указанный период времени QuickReport
Помогите пожалуйста разобраться с ошибкой при нажатии Кнопки Отчет. Выскакивает такая ошибка.Вот код программыprocedure...

Вывести информацию об исполнителях и их композициях созданных в указанный период времени
в текстовом файле находится информация об исполнителях. Каждая запись имеет вид: исполнитель, название альбома, название композиции,...

Найти прирост суммы вклада за указанный период времени, используя циклы
Напишите программу с помощью циклов.Гражданин 1 марта открыл счет в банке, вложив 1000 руб. Через каждый месяц размер вклада увеличивается...

Идентификация GSM абонента с БД
Вопрос такой: Есть магазин с БД MySQL на хостинге. В БД есть таблица с клиентами магазина где в отдельном поле хранится номер телефона...

Вопрос про абонента...
Хочу спросить.. Я позвонил абоненту на мобилу, полминуты говорили, и слышу &quot;Абонент находится вне зоны оператора&quot; (или как то так)....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru