1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:
49:
50:
51:
52:
53:
|
ИЗМЕНИТЕ ФУНКЦИЮ [dbo]. [udf_getrates_3] (datetime @date, @util varchar (50))
ВОЗВРАЩАЕТ таблицу @tbl (ДЕНЬГ chargerate, ДЕНЬГ взимания налогов, ДЕНЬГ caprate, поплавок ChargeCap, деньг StandingDayCharge)
КАК
НАЧНИТЕ
объявите чарс @dw (1)
установите @dw = вышл (DATENAME (DW, @date), 1)
объявите @hr int
установите @hr = datepart (час, @date)
введите @tbl
выберите верхнюю часть 1 --EffectiveStartDate, EffectiveEndDate,
СЛУЧАЙ КОГДА @dw = «s» и ( (@hr между datepart (часом, weekenddaystart) и datepart (часом, weekenddayend) и isnull (weekenddaycost, 0) <> 0)
или (@hr НЕ между datepart (часом, weekenddaystart) и datepart (часом, weekenddayend) и isnull (weekendnightcost, 0) <> 0))
ПОСЛЕ ЭТОГО
СЛУЧАЙ КОГДА @hr между datepart (часом, weekenddaystart) и datepart (часом, weekenddayend)
ПОСЛЕ ЭТОГО weekenddaycost
ДРУГОЕ weekendnightcost
КОНЕЦ
ЕЩЕ
СЛУЧАЙ КОГДА @hr между datepart (часом, weekdaystart) и datepart (часом, weekdayend)
ПОСЛЕ ЭТОГО weekdaycost
ДРУГОЕ weeknightcost
КОНЕЦ
КОНЕЦ, climateChangeLevyRate, ((chargeablecapacity*capacityrate)), chargeablecapacity, isnull (StandingDayCharge, 0)
ОТ EnergySuiteDB.dbo.Rates
где UtilityName=@util
И @date между EffectiveStartDate и EffectiveEndDate
Заказ desc удостоверения личности -- получите «последний» рядок покрывает спрошенную дату.
если @@rowcount = 0
введите @tbl
выберите верхнюю часть 1 --EffectiveStartDate, EffectiveEndDate,
СЛУЧАЙ КОГДА @dw = «s» и ( (@hr между datepart (часом, weekenddaystart) и datepart (часом, weekenddayend) и isnull (weekenddaycost, 0) <> 0)
или (@hr НЕ между datepart (часом, weekenddaystart) и datepart (часом, weekenddayend) и isnull (weekendnightcost, 0) <> 0))
ПОСЛЕ ЭТОГО
СЛУЧАЙ КОГДА @hr между datepart (часом, weekenddaystart) и datepart (часом, weekenddayend)
ПОСЛЕ ЭТОГО weekenddaycost
ДРУГОЕ weekendnightcost
КОНЕЦ
ЕЩЕ
СЛУЧАЙ КОГДА @hr между datepart (часом, weekdaystart) и datepart (часом, weekdayend)
ПОСЛЕ ЭТОГО weekdaycost
ДРУГОЕ weeknightcost
КОНЕЦ
КОНЕЦ, climateChangeLevyRate, ((chargeablecapacity*capacityrate)), chargeablecapacity, isnull (StandingDayCharge, 0)
ОТ EnergySuiteDB.dbo.Rates
где UtilityName=@util
заказ desc EffectiveEndDate -- самое высокое enddate принадлежит «для того чтобы грести 1» все заволакивание/тариф уплаты по невыполненным обязательствам.
возвращение
КОНЕЦ
|