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?