Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: Базы данных MS SQL

  Все выпуски  

RFpro.ru: Базы данных MS SQL


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Гуревич Александр Львович
Статус: Профессионал
Рейтинг: 4538
∙ повысить рейтинг »
Megaloman
Статус: Профессионал
Рейтинг: 1404
∙ повысить рейтинг »
Sipan
Статус: 3-й класс
Рейтинг: 297
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Базы данных: MS SQL, Oracle

Номер выпуска:68
Дата выхода:11.06.2010, 22:30
Администратор рассылки:Victor Pyrlik, Модератор
Подписчиков / экспертов:153 / 64
Вопросов / ответов:1 / 1

Вопрос № 178964: Уважаемые эксперты. Вопрос: Имеется база данных с полями: Kard -символьное поле карточек, Dat1 - дата. Карточка может использоваться несколько раз в день. Количество строк в таблице около 200000. Необходимо составить SQL-запрос, который выводит номер...



Вопрос № 178964:

Уважаемые эксперты. Вопрос: Имеется база данных с полями: Kard -символьное поле карточек, Dat1 - дата. Карточка может использоваться несколько раз в день. Количество строк в таблице около 200000. Необходимо составить SQL-запрос, который выводит номера Kard которые использовались в день больше определенного числа раз - Kol и вывести эту дату и количество раз использований карты в этот день.
То есть должна получиться следующая таблица:
Kard Dat1 (Количество использований карты в день)
2345 01.02.2010 4
2347 02.02.2010 5
5879 02.02.2010 5

Отправлен: 06.06.2010, 22:12
Вопрос задал: KazAndr, 1-й класс
Всего ответов: 1
Страница вопроса »


Отвечает Victor Pyrlik, Модератор :
Здравствуйте, KazAndr.
Возможно так:
Код:

SELECT A.CARD, A.DAT1, COUNT(*) COUNT_WORK FROM TEST A
WHERE (SELECT COUNT(*) FROM TEST T WHERE T.CARD = A.CARD AND T.DAT1 = A.DAT1) > 1
GROUP BY A.CARD, A.DAT1


Тестовые данные:
CARD DAT1
2345 05.06.2010
2345 05.06.2010
2345 06.06.2010
2346 06.06.2010
2346 06.06.2010
2346 06.06.2010
2347 05.06.2010
2347 05.06.2010
2347 05.06.2010
2347 05.06.2010
2347 06.06.2010
2347 06.06.2010

Результат:
CARD DAT1 KOL
2345 06.06.2010 1
2347 05.06.2010 4
2347 06.06.2010 2
2345 05.06.2010 2
2346 06.06.2010 3


-- 1 Это ваше KOL.. можно задать как параметр (указав 2, 3 и т.д.)
Но для больших наборов да нных, лучше ограничивать диапазон, например:
AND A.DAT1 BETWEEN SYSDATE-30 AND SYSDATE

Ну и для условия: «Вывести все номера всех карт и дни обращения, для которых количество обращений максимально»
Код:

SELECT CARD, DAT1, MAX(KOL) KOL FROM
(
SELECT CARD, DAT1, COUNT(*) KOL FROM TEST A
GROUP BY CARD, DAT1
) T GROUP BY CARD, DAT1
HAVING MAX(KOL) >= (SELECT MAX((SELECT COUNT(*) FROM TEST C WHERE C.CARD = B.CARD AND C.DAT1 = B.DAT1 )) FROM TEST B WHERE B.CARD = T.CARD)

результат запроса:
CARD DAT1 KOL
2347 05.06.2010 4
2345 05.06.2010 2
2346 06.06.2010 3


-----
Жизнь игрушка – пока играешь сам..

Ответ отправил: Victor Pyrlik, Модератор
Ответ отправлен: 11.06.2010, 16:14
Номер ответа: 262071
Россия, Екатеринбург
Тел.: 89043822027
ICQ # 490191733
Абонент Skype: stells00

Оценка ответа: 5

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 262071 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.16 от 26.05.2010

    В избранное