DB
Dotyczy:kolumna obliczeniowatabela obliczeniowaMeasureobliczenia wizualne
Zwraca amortyzację środka trwałego dla określonego okresu przy użyciu metody fixedmalejącego salda.
Składnia
DB(<cost>, <salvage>, <life>, <period>[, <month>])
Parametry
Termin | Definicja |
---|---|
cost |
Początkowy koszt zasobu. |
salvage |
value na końcu amortyzacji (czasami nazywane ratowcą value środka trwałego). Ten value może być 0. |
life |
Liczba okresów, w których umortyzowany jest zasób (czasami nazywany okresem eksploatacji zasobu). |
period |
Okres, dla którego chcesz calculate amortyzację. Okres musi używać tych samych jednostek co okres życia. Musi należeć do zakresu od 1 and życia (włącznie). |
month |
(Opcjonalnie) Liczba miesięcy w firstyear. If month zostanie pominięty, przyjmuje się, że ma wartość 12. |
Zwracanie Value
Amortyzacja w określonym przedziale czasu.
Uwagi
Metoda fixedmalejącego salda oblicza amortyzację w fixedrate. DB używa następujących formuł do calculate amortyzacji w danym okresie:
$$(\text{cost} — \text{łączna amortyzacja z poprzednich okresów}) \times \text{rate}$$
gdzie:
- $\text{rate} = 1 - ((\frac{\text{salvage}}{\text{cost}})^{(\frac{1}{\text{life})})\text{, zaokrąglone do trzech miejsc dziesiętnych}$
Amortyzacja okresów firstandlast jest szczególną sprawą.
W okresie firstDB używa następującej formuły:
$$\frac{\text{cost} \times \text{rate} \times \text{month}}{12}$$
W okresie lastDB używa następującej formuły:
$$\frac{(\text{cost} - \text{łączna amortyzacja z poprzednich okresów}) \times \text{rate} \times (12 - \text{month})}{12}$$
kropka andmonth są zaokrąglane do najbliższej liczby całkowitej.
Zwracany jest errorif:
- koszt < 0.
- ratuj < 0.
- < życia 1.
- okres < 1 or okres > życia.
- month < 1 ormonth> 12.
Ta funkcja jest not obsługiwana do użycia w trybie DirectQuery w przypadku użycia w kolumnach obliczeniowych or reguł zabezpieczeń na poziomie wiersza.
Przykłady
Przykład 1
Następujące zapytanie DAX:
EVALUATE
{
DB(1000000, 0, 6, 1, 2)
}
Zwraca amortyzację środka trwałego w ciągu last dwóch miesięcy firstyear, zakładając, że będzie wart \$0 po 6 latach.
[Value] |
---|
166666.666666667 |
Przykład 2
Poniżej obliczana jest łączna amortyzacja all aktywów w różnych latach w okresie ich istnienia. W tym przypadku firstyear obejmuje tylko 7 miesięcy amortyzacji, andlastyear obejmuje tylko 5 miesięcy.
DEFINE
VAR NumDepreciationPeriods = MAX(Asset[LifeTimeYears])+1
VAR DepreciationPeriods = GENERATESERIES(1, NumDepreciationPeriods)
EVALUATE
ADDCOLUMNS (
DepreciationPeriods,
"Current Period Total Depreciation",
SUMX (
FILTER (
Asset,
[Value] <= [LifetimeYears]+1
),
DB([InitialCost], [SalvageValue], [LifetimeYears], [Value], 7)
)
)