Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2006.04.16;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.46 MB
Время: 0.042 c
2-1144120445
vegarulez
2006-04-04 07:14
2006.04.16
Не пойму что случилось с панелью свойстформы (Object Inspector)?


3-1140436796
Варяг
2006-02-20 14:59
2006.04.16
Прогр-ное создание индексного файла для FoxPro


2-1143721976
Scavenger
2006-03-30 16:32
2006.04.16
RadioGroup


15-1143217541
Ученик чародея
2006-03-24 19:25
2006.04.16
Принтсервер Surecom EP-903X-U печать из DOS-а.


2-1143713097
Yegorchic
2006-03-30 14:04
2006.04.16
CheckBox.Caption в 2 строки





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский