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

Вниз

вопрос по запросу   Найти похожие ветки 

 
SOFTMASTER   (2001-12-09 19:54) [0]

Всем привет!
Столкнулся с проблемой:
есть у меня база данных, участок, который сейчас рассматривается выглядит следующим образом: Есть таблица, в нее забивается основная информация- дата оформления, номер документа и т.п.
Подчиненная таблица выглядит след. образом: связь по номеру документа, имя исполнителя (код) и сумма услуги.
Есть таблица исполнителей: там код и имя.
Теперь мне нужно получить информацию следующего вида: вывести всех исполнителей и посчитать для каждого сумму услуг за определенный день.Таким образом, WHERE можно использовать, но он выводит только записи , которые работали в этот день, а надо всех, даже пустых . Надо использовать что-то типа JOIN, но как это сделать правильно?
Использовал конструкцию

select Workers.Name,sum(ServItems.Price)
from (Workers left join servitems
on
ServItems.Wname=Workers.Code
left
join Servs
on (Servs.Dat_="05.12.2001"
and Servs.DocNum=ServItems.DocNum))

group by Workers.Name

но не работает отбор по дате, он выдает полную сумму за все время существования.
INNER JOIN тоже используется как WHERE, так что не получается.
Мастера, подскажите как лучше сделать, ПОЖАЛУЙСТА!


 
evgeg   (2001-12-09 20:28) [1]

А хранимой процедурой не хочешь воспользоваться?
В ней это элементарно делается.


 
Softmaster   (2001-12-09 20:55) [2]

>evgeg
Как ею воспользоваться?


 
evgeg   (2001-12-09 21:23) [3]

Надо создать процедуру:

create procedure otchet
(day date)
returns
(Name varchar (30),
Summ double precision)
as
declare variable Code integer;
begin
for select Code, Name from Workers
into :Code, :Name
do
begin
summ = null;
select sum (SI.Price) from ServItems SI, Servs S
where SI.WName = :Code and SI.DocNum = S.DocNum and S.Dat_ = :day
into :summ;
if (summ is null) then summ = 0;
suspend;
end
end


Выбов процедуры:

select * from otchet ("01.11.2001")


 
Softmaster   (2001-12-10 20:30) [4]

СПАСИБО



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

Форум: "Базы";
Текущий архив: 2002.01.14;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.55 MB
Время: 0.167 c
3-42338
Smile
2001-12-10 09:59
2002.01.14
Может быть глупый вопрос, но ....


3-42346
Yakudza
2001-12-08 21:07
2002.01.14
Word


3-42378
well
2001-12-10 15:02
2002.01.14
SQL & paradox


1-42519
Andrey196
2001-12-26 16:15
2002.01.14
Как из события одново компонента вызвать событие другово компонета


4-42627
Romualds Stashans
2001-11-15 09:57
2002.01.14
Как удалить папку содержащую файлы





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