Avatar billede svjensen Nybegynder
18. november 2010 - 09:57

Gange med forskellige variable i krydstabuleringsforespørgsel

Jeg anvender følgende (eksempelvise) forespørgsel til at udtrække og summere data:

TRANSFORM Sum(tblTest.Value) AS SumOfValue
SELECT tblTest.ExpenseType
FROM tblTest
GROUP BY tblTest.ExpenseType
PIVOT tblTest.Year;

Alle data er gemt i prisniveau 2010 og skal nu opskrives til prisniveau 2011.
Det kunne fx gøres vha. en funktion, der beregner multiplikatoren, som så kan anvendes således:

TRANSFORM Sum(tblTest.Value)*GetPriceLevel() AS SumOfValue
SELECT tblTest.ExpenseType
FROM tblTest
GROUP BY tblTest.ExpenseType
PIVOT tblTest.Year;

Og nu kommer vi så til mit problem.
tblTest.ExpenseType kan være én af to værdier - løn ('Salary') og drift ('Expenses'), og hver af dem har sin egen multiplikator, der skal anvendes til at opregne dem til prisniveau 2011.
P.t. anvender jeg to forespørgsler til at beregne dette - og får dermed to recordset:

TRANSFORM Sum(tblTest.Value)*GetPriceLevelSalary() AS SumOfValue
SELECT tblTest.ExpenseType
FROM tblTest
WHERE tblTest.ExpenseType = 'Salary'
GROUP BY tblTest.ExpenseType
PIVOT tblTest.Year;

TRANSFORM Sum(tblTest.Value)*GetPriceLevelExpenses() AS SumOfValue
SELECT tblTest.ExpenseType
FROM tblTest
WHERE tblTest.ExpenseType = 'Expenses'
GROUP BY tblTest.ExpenseType
PIVOT tblTest.Year;

Mit spørgsmål er så, om det kan gøres i én forespørgsel, og dermed give mig ét recordset?
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Dyk ned i databasernes verden på et af vores praksisnære Access-kurser

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester