Почетный модератор
Эксперт HTML/CSSЭксперт PHP
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
1

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

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

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

Есть таблица с абонентами и звонками (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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.02.2015, 09:04
Ответы с готовыми решениями:

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

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

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

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

8
Почетный модератор
Эксперт по компьютерным сетямЭксперт Windows
28046 / 15779 / 983
Регистрация: 15.09.2009
Сообщений: 67,752
Записей в блоге: 78
10.02.2015, 09:50 2
Спросил коллегу... к сожалению он не помнит логина от форума, поэтому поработаю испорченным телефоном...
Цитата Сообщение от KOPOJI Посмотреть сообщение
WHERE `date` BETWEEN 1422910800 AND 1423515600
спрашивает какой формат имеет "date" его смущает числовое значение... "1422910800"
1
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
10.02.2015, 09:55  [ТС] 3
UNIX_TIMESTAMP. По сути, это не важно - есть возможность поменять на любой другой, хоть DATETIME (там дата + время). Просто, повторюсь, это SQLite, и типа даты как такового там нет.
0
1652 / 1151 / 173
Регистрация: 23.07.2010
Сообщений: 6,856
10.02.2015, 10:31 4
а что покажет
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
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
10.02.2015, 10:38 5
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
479 / 392 / 112
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
10.02.2015, 11:02 6
Цитата Сообщение от 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
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
10.02.2015, 11:21 7
Цитата Сообщение от Bit_Man Посмотреть сообщение
А вот тут подвох. Если их будет несколько?
в условии по поводу этого ни слова,
я бы писал так
SQL
1
SELECT TOP(1) WITH ties `from`, COUNT(`from`) 'cnt'
но это t-sql, какие возможности есть в лайте я не знаю.
1
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
10.02.2015, 14:34  [ТС] 8
Цитата Сообщение от 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
pincet
10.02.2015, 15:55     Вывод самого активного абонента и количество звонков от этого абонента за указанный период времени
  #9

Не по теме:


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

0
10.02.2015, 15:55
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.02.2015, 15:55
Помогаю со студенческими работами здесь

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

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

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

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

Skype - нет видео от абонента
5720. ОС Debian Squeeze. Прошу помочь в настройке Skype. Проблема такая - при работе в видеорежиме...

Поиск абонента с заданным именем
В текстовом файле находятся записи о номерах телефонов. В каждой строке записана информация об...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru