Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.07.08;
Скачать: CL | DM;

Вниз

Как составить запрос. Неужели это невозможно.   Найти похожие ветки 

 
AndrewK ©   (2002-06-14 15:57) [0]

Уважаемые мастера.

Есть две таблицы Colors и Logs
В таблице Colors храняться названия восьми цветов с номерами от 0 до 7. В таблице Logs храняться записи в следующей структуре:

Logs
-----------------------------
IDR int
DateReg datetime
Color_ID int
User_ID int

Colors
-----------------------------
Code int
Name varchar(50)


Поле Colors.Code связано с Logs.Color_ID

Каждый день, пользователи выбирают свой цвет из восьми. Данные попадают в базу.

Мне надо составить отчет по динамике изменения предпочтений пользователей по датам. Главное, чтобы результирующая выборка представляла собой следующее:

Color_ID DateReg ColCount
-----------------------------------------------------------
0 01.01.2002 1
1 01.01.2002 3
2 01.01.2002 5
3 01.01.2002 4
4 01.01.2002 3
5 01.01.2002 0
6 01.01.2002 5
7 01.01.2002 0
0 02.01.2002 8
1 02.01.2002 6
2 02.01.2002 1
3 02.01.2002 0
4 02.01.2002 0
5 02.01.2002 8
6 02.01.2002 7
7 02.01.2002 1


Главное, чтобы в колонке Color_ID были представлены все восемь цветов (их коды от 0 до 7) на каждую дату. Это важно.

Стандартный JOIN здесь не работает.

Один из возможных вариантов решения - использование конструированного отчета в хранимой процедуре с использованием UNION , но это не красиво и не оптимально.

Неужели нет способа решить задачу одним запросом.

Заранее признателен за помощь.


 
DPetrovich ©   (2002-06-14 16:20) [1]

я подобную проблему решаю тем что создаю вспомогательную таблицу дат, скажем DATES (DateReg datetime), затем заполняю её всеми возможными записями... и запрос тогда

select
Color_ID=C.Code,
D.DateReg,
ColCount=
sum(case when L.Color_ID is not null then 1 else 0 end)
from
DATES D
join Colors C
left join Logs L on
L.Color_ID=C.Code and L.DateReg=D.DateReg


по-моему так


 
xNick   (2002-06-14 16:37) [2]

Напиши так:

SELECT Color_ID,DateReg,Count(*) as ColCount
FROM Logs
GROUP BY Color_ID,DateReg
ORDER BY 2,1


По-моему должно сработать



Страницы: 1 вся ветка

Текущий архив: 2002.07.08;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.014 c
4-23823
AlexanderSK
2002-05-06 12:27
2002.07.08
GetVolumeInformation


3-23502
Fareader
2002-06-17 13:37
2002.07.08
pFIBQuery.BatchOutput(RawOutput)


14-23726
PTE
2002-06-05 19:05
2002.07.08
RXкомпонент


14-23772
Nevercomes
2002-06-07 23:24
2002.07.08
GTA 3 WinXp+Nvidia GeForse = с графикой проблемы!!!


7-23820
Torry
2002-04-12 14:24
2002.07.08
Как сделать чтобы форма не была не активной