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

Вниз

Сложный SQL-запрос   Найти похожие ветки 

 
Kostafey ©   (2006-12-22 14:52) [0]

Уважаемые мастера ! Помоготе пожалуйста составить SQL-запрос

Есть слудующие таюлицы:
ZVK1 - сведния о заявках
ZVK41 - сведения о боевой работе
PCH - сведения о названии части

Необходимо составить запрос, который бы показвал сколько стволов того или иного типа исползуется той или иной частью.
Тип ствола ZVK41.TS1, количество стволов, использованных на одном пожаре ZVK41.KS1

Именно то, что на одном пожаре может быть использовано больше одного ствола и составляет главную сложность.
Т.е. одним count() все не решается.

Таблицы ZVK1 и ZVK41 связаны по полю N_ZVK

Итак, ести предположить, что на пожаре может быть использовано или 1 или 2 ствола, то запрос мог бы иметь следующий вид:

select                                                                          
p.PCH_NAME,

case
when (z1.zcnt is null) and (z2.zcnt is null) then 0
when (z1.zcnt is null) then z2.zcnt
when (z2.zcnt is null) then z1.zcnt
else  z1.zcnt+z2.zcnt
end as Kol1
                                                   
from                                                                            
PCH p        
                                                               
--Тип ствола 1, количество стволов 1
LEFT JOIN (                                                                    
select z.PCH_COD,  count(z.PCH_COD) zcnt
from ZVK1 z, ZVK41 z41
where (z.N_ZVK=z41.N_ZVK)
  and (z41.TS1=1)
  and (z41.KS1>=1)
group by                                                                      
 z.PCH_COD
) z1 ON z1.PCH_COD= p.PCH_COD

--Тип ствола 1, количество стволов 2
LEFT JOIN (                                                                    
select z.PCH_COD,  count(z.PCH_COD) zcnt
from ZVK1 z, ZVK41 z41
where (z.N_ZVK=z41.N_ZVK)
  and (z41.TS1=1)
  and (z41.KS1>=2)
group by                                                                      
 z.PCH_COD
) z2 ON z2.PCH_COD= p.PCH_COD

order by  p.PCH_NAME                                                        


Этот код успешно выполняется, но если предположить, что на пожаре может быть использовано до 10 (в редких случаях даже больше) стволов
одного типа, то составить такой запрос уже не так просто.
Возможно есть более рациональный путь чем то что я привел выше  ?


 
Kostafey ©   (2006-12-22 15:10) [1]

Чуть не забыл СУБД SQL Server 2005


 
Kostafey ©   (2006-12-23 00:38) [2]

А ладно ! Решил проблему влоб:

for i:=1 to 10
 //.................



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

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

Наверх




Память: 0.48 MB
Время: 0.087 c
2-1166974460
AzzHell
2006-12-24 18:34
2007.01.14
Как зделать чтобы прога при работе занимала меньше оперативы?


2-1166887620
BanserAnt
2006-12-23 18:27
2007.01.14
Кто в чате?


2-1167052236
Trible
2006-12-25 16:10
2007.01.14
отослать сообщение процесу, созданного с CreateProcess


6-1155736414
цыц
2006-08-16 17:53
2007.01.14
TWSocket разбор принятых пакетов


15-1166474896
Piter
2006-12-18 23:48
2007.01.14
Лишение прав за вождение в пьяном виде