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

Вниз

функция, которая выбирает товары   Найти похожие ветки 

 
HanIP   (2004-08-31 08:35) [0]

Такой вопрос есть функция, которая выбирает товары по следующему условию: если в текущем месяце есть приход или расход, то вывести эту запись, а если нет то вывести запись, с максимальным периодом и не нулевым  приходом или расходом. Тектс ее таков:CREATE FUNCTION dbo.MainF (@ID_Period int)  
RETURNS Table AS  
     return SELECT  Pr.ID_Prod, Pr.ID_Tov, Pr.Cena, Pr.ID_Edin, Pr.ID_Schet,
                               dbo.Prihod (@ID_Period, Pr.ID_Period, Pr.Prihod) as Prih, dbo.Prihod (@ID_Period, Pr.ID_Period,
                               Pr.Prihod)*cena as P_Summ, dbo.Rashod (@ID_Period, Pr.ID_Period, Pr.Rashod) as Rash,
                               dbo.Rashod (@ID_Period, Pr.ID_Period, Pr.Rashod)*cena as R_Summ,  
                               dbo.Ostatok(Pr.ID_Tov, Pr.Partija,@Id_Period) AS Ost_Nach, (dbo.Ostatok(Pr.ID_Tov, Pr.Partija,@Id_Period)+
                               dbo.Prihod (@ID_Period, Pr.ID_Period, Pr.Prihod)-dbo.Rashod (@ID_Period, Pr.ID_Period, Pr.Rashod))*cena as O_Summ,
                               dbo.Ostatok(Pr.ID_Tov, Pr.Partija,@Id_Period)+dbo.Prihod (@ID_Period, Pr.ID_Period, Pr.Prihod)-
                               dbo.Rashod (@ID_Period, Pr.ID_Period, Pr.Rashod) as Ost, Pr.ID_Period, Pr.Partija,
                               Pr.Cena * dbo.Ostatok(Pr.ID_Tov, Pr.Partija,@Id_period)
                               AS ON_Summ
FROM         dbo.Prod  pr
                                   Where  ((
                                                    (
                                                     (dbo.Rashod (@ID_Period, Pr.ID_Period, Pr.Rashod)<>0)or
                                                     (dbo.Prihod (@ID_Period, Pr.ID_Period, Pr.Prihod)<>0)
                                                    )
                                                    and(Pr.ID_Period=@ID_Period)
                                                  )or
                                                    ( (Pr.Rashod<>0)or
                                                     (Pr.Prihod<>0)and
                                                     (Pr.ID_Period=(select max(P.ID_Period)  from dbo.Prod P where (P.ID_Period<@ID_Period)and(P.ID_Tov=PR.ID_Tov)and(P.Partija=Pr.Partija)
               and (
                                                              (P.Rashod<>0)or
                                                              (P.Prihod<>0)
                                                            )
                                                                           )
                                                   )
                                                  )
                                                 )
еще используются функции Ostatok - остаток на начало месяца(работает это проверно), Rashod - определяет расход товара в текущем месяце, на случай если росхода нет то выводить ноль, Prihod - такая же как и Rashod отолько для прихода. Проблема в том, что выводятся записи с приходом и еще нулевые за прошлый месяц, которые не должны браться, как от этого уйти?, может в условии где ошибка?


 
SolDen   (2004-08-31 15:15) [1]

С ума сойти!



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

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

Наверх




Память: 0.46 MB
Время: 0.039 c
1-1094656072
hgd
2004-09-08 19:07
2004.09.26
Как получить время текущее с милисекундами?


1-1094711126
EthernalWonderer
2004-09-09 10:25
2004.09.26
Перехват клавиши мыши, когда курсор над любым элементом окна


4-1092250264
Forelli
2004-08-11 22:51
2004.09.26
Как обращаться к окнам созданным с помощью CreateWindow?


4-1092521045
Darthman
2004-08-15 02:04
2004.09.26
Как перехватить мультимедиа клавиши на клавиатуре?


1-1094729619
Sandman25
2004-09-09 15:33
2004.09.26
Оптимизация try finally





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