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

Вниз

Объединение таблиц для создания отчета   Найти похожие ветки 

 
TimScorp ©   (2006-04-03 18:55) [0]

Доброго времени суток!!!

Вопрос в следующем:

Имеем три таблицы в Access с полями:

Таблица 1: Fam - текст, AP - числовое, Date - Дата
Таблица 2: Fam - текст, AM - числовое, Date - Дата
Таблица 3: Fam - текст, SV - числовое, Date - Дата


 
TimScorp ©   (2006-04-03 18:56) [1]

Допустим в Таблице 1 данные:

Иванов      1     31.03.2006
Петров      1     30.03.2006
Иванов      1     01.04.2006
Сидоров    1     30.03.2006
Иванов      1     01.04.2006
Сидоров    1     02.04.2006

В Таблице 2:

Сидоров     1    30.03.2006
Петров       1    31.03.2006

В Таблице 3:

Иванов      1    01.04.2006


 
TimScorp ©   (2006-04-03 18:56) [2]

Теперь нужно создать отчет (FreeReport) что бы была таблица вида:

 Fam             AP           AM           SV
Иванов           3             0             1
Петров           1             1             0
Сидоров         2             1             0
Итого         6            2             1            

Мне приходится проходить по полям всех трех таблиц, суммировать данные и заносить их в четвертую таблицу в которой есть поля : Fam, AP, AM, SV и заносить туда данные.
Можно ли это сделать проще???

С уважением TimScorp.


 
TimScorp ©   (2006-04-03 20:35) [3]

Удалено модератором
Примечание: Создание пустых соощений


 
Johnmen ©   (2006-04-03 21:37) [4]

Запрос и запроса работает?


 
sniknik ©   (2006-04-03 22:18) [5]

вот так.

SELECT a1.Fam, AP, AM, SV FROM
((SELECT Fam, Sum(AP) AS AP  FROM T1 GROUP BY Fam) AS a1
LEFT JOIN
(SELECT Fam, Sum(AM) AS AM FROM T2 GROUP BY Fam) AS a2 ON a1.Fam = a2.Fam)
LEFT JOIN
(SELECT Fam, Sum(SV) AS SV FROM T3 GROUP BY Fam) AS a3
ON a1.Fam = a3.Fam


будет похоже...


 
TimScorp ©   (2006-04-03 22:24) [6]

ща попробую

С уважением TimScorp


 
Johnmen ©   (2006-04-03 22:42) [7]

Тогда почему бы не так?

SELECT Fam, SUM(F) FROM
(SELECT Fam, AP AS F FROM T1
UNION ALL
SELECT Fam, AM AS F FROM T2
UNION ALL
SELECT Fam, SV AS F FROM T3) AS TT
GROUP BY Fam


 
sniknik ©   (2006-04-03 23:12) [8]

можно, но тогда так, чтобы было похоже

SELECT Fam, Sum(AP) AS AP, Sum(AM) AS AM, Sum(SV) AS SV FROM
(SELECT Fam,AP,0 AS AM,0 AS SV FROM T1
UNION ALL
SELECT Fam,0,AM,0 FROM T2
UNION ALL
SELECT Fam,0,0,SV FROM T3)  AS tt
GROUP BY Fam


 
Johnmen ©   (2006-04-03 23:18) [9]


> sniknik ©   (03.04.06 23:12) [8]


Да-да...



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

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

Наверх




Память: 0.46 MB
Время: 0.039 c
2-1144224732
Nick_serov
2006-04-05 12:12
2006.04.16
Расчеты в Grid е


2-1144168672
Volkodav
2006-04-04 20:37
2006.04.16
Можно ли заставить прогу включить комп например в 10:30?


2-1144136085
Klopan
2006-04-04 11:34
2006.04.16
Copy


2-1143697782
mariya_mezenceva
2006-03-30 09:49
2006.04.16
аналог for each


2-1143489174
EHOT
2006-03-27 23:52
2006.04.16
Media File





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский