Главная страница
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.48 MB
Время: 0.015 c
6-23711
Jeck
2002-04-29 09:37
2002.07.08
Мастера, подскажите


6-23708
VS2001
2002-04-18 18:03
2002.07.08
Помогите ПЛИЗ !!! Проблема с удалением файла на ФТП сервере


7-23807
Dizer
2002-04-16 11:05
2002.07.08
Интерфейс RS-485


1-23628
andwcomm
2002-06-25 18:43
2002.07.08
преобразование Unix времени


7-23804
Hewer
2002-04-15 10:45
2002.07.08
У кого глюк: у TreeView или у меня?