In Bezug auf
diesen Artikel möchte ich meine Abfrage von aussen eingrenzen.
Ich hab jetzt eine Stored Procedure erstellt, die mir für ein gegebenes Datum eine Liste aller Artikel mit zu dem Zeitpunkt gültigem Datum gibt. Die Stored Procedure klappt an sich wunderbar.
Nur, wie kann ich diese SP jetzt von aussen aufrufen, und noch zusaätzliche Filterbedingungen einbringen, wie z.B. nur Artikel mit einer Artikelnummer > irgendwas.
Hier mal die SP:
SQL-Code:
CREATE procedure spArtikelPreise (@Datum datetime, @EKVK int, @LanguageCode varchar(3))
as
if @Datum is null begin
set @Datum = dbo.Datum(getdate())
end
if @EKVK is null begin
set @EKVK = 1
end
if @LanguageCode is null begin
set @LanguageCode = 'D'
end
SELECT dbo.Artikel.id AS AR_ID, dbo.Preise.id AS PR_ID, dbo.Artikel.ArtikelNr AS AR_Nr, round(dbo.Preise.Preis/dbo.Preise.Menge,2) AS PR_Preis,
dbo.Preise.Datum AS PR_Datum, dbo.Preise.EKVK AS PR_EKVK, dbo.Language.Code AS L_Code, dbo.ArtikelBezeich.BezeichnungKurz,
dbo.ArtikelBezeich.BezeichnungLang
FROM dbo.Artikel INNER JOIN
dbo.Preise ON dbo.Artikel.ArtikelNr = dbo.Preise.fiArtikel INNER JOIN
dbo.ArtikelBezeich ON dbo.Artikel.ArtikelNr = dbo.ArtikelBezeich.fiArtikel INNER JOIN
dbo.Language ON dbo.ArtikelBezeich.Sprache = dbo.Language.ID INNER JOIN
( SELECT fiArtikel, ISNULL(MAX(Datum), dbo.Datum(@Datum)) AS Datum, EKVK
FROM dbo.Preise
WHERE (Datum <= @Datum)
GROUP BY fiArtikel, EKVK
HAVING (MAX(Datum) <= @Datum)
) pt
ON dbo.Preise.fiArtikel = pt.fiArtikel AND dbo.Preise.Datum = pt.Datum AND
dbo.Preise.EKVK = pt.EKVK
WHERE (dbo.Preise.Datum < @Datum) and pt.EKVK = @EKVK and dbo.Language.Code = @LanguageCode
ORDER BY dbo.Artikel.id
Der Aufruf
exec spArtikelPreise null,null,null
klappt.
Ich suche was wie
select * from (exec spArtikelPreise null,null,null) where AR_Nr > '10000'
Das klappt so natürlich nicht, aber Ihr wisst was ich meine.