У меня есть следующие две таблицы
activity(activity_id, title, description, group_id)
statistic(statistic_id, activity_id, date, user_id, result)
group_id и user_id приходят из активного каталога. Результатом является целое число.
Учитывая user_id и диапазон дат 6 дней (понедельник-суббота), которые я рассчитал на стороне бизнес-логики, и тот факт, что некоторые даты в диапазоне дат могут не иметь статистического результата для конкретного дата (т. е. день1 и день 4, возможно, ввели статистические строки для конкретной операции, но может не быть записей для дней 2, 3, 5 и 6), как я могу получить результат SQL в следующем формате? Имейте в виду, что если конкретное действие не имеет записи на конкретную дату в таблице статистики, то этот день должен возвращать 0 в результате SQL.
activity_id group_id day1result day2result day3result day4result day5result day6 result
----------- -------- ---------- ---------- ---------- ---------- ---------- -----------
sample1 Secured 0 5 1 0 2 1
sample2 Unsecured 1 0 0 4 3 2
Примечание. В настоящее время я планирую обработать это в бизнес-логике, но для этого потребуется несколько запросов (один для создания списка отдельных действий для этого пользователя для диапазона дат, и один для каждой операции, циклически повторяющейся для каждой даты для результат или отсутствие результата, чтобы заполнить 2-е измерение массива результатами, связанными с датой). Это может закончиться 50+ запросами для каждого пользователя в диапазоне дат, что кажется мне излишним.
У меня это работало в течение 4 дней, и я могу заставить его работать в течение всех 6 дней, но это кажется излишним. Есть ли способ упростить это?:
SELECT d1d2.activity_id, ISNULL(d1d2.result1,0) AS day1, ISNULL(d1d2.result2,0) AS day2, ISNULL(d3d4.result3,0) AS day3, ISNULL(d3d4.result4,0) AS day4
FROM
(SELECT ISNULL(d1.activity_id,0) AS activity_id, ISNULL(result1,0) AS result1, ISNULL(result2,0) AS result2
FROM
(SELECT ISNULL(statistic_result,0) AS result1, ISNULL(activity_id,0) AS activity_id
FROM statistic
WHERE user_id='jeremiah' AND statistic_date='11/22/2011'
) d1
FROM JOIN
(SELECT ISNULL(statistic_result,0) AS result2, ISNULL(activity_id,0) AS activity_id
FROM statistic WHERE user_id='jeremiah' AND statistic_date='11/23/2011'
) d2
ON d1.activity_id=d2.activity_id
) d1d2
FULL JOIN
(SELECT d3.activity_id AS activity_id, ISNULL(d3.result3,0) AS result3, ISNULL(d4.result4,0) AS result4
FROM
(SELECT ISNULL(statistic_result,0) AS result3, ISNULL(activity_id,0) AS activity_id
FROM statistic WHERE user_id='jeremiah' AND statistic_date='11/24/2011'
) d3
FULL JOIN
(SELECT ISNULL(statistic_result,0) AS result4, ISNULL(activity_id,0) AS activity_id
FROM statistic WHERE user_id='jeremiah' AND statistic_date='11/25/2011'
) d4
ON d3.activity_id=d4.activity_id
) d3d4
ON d1d2.activity_id=d3d4.activity_id
ORDER BY d1d2.activity_id