Advertisement
Guest User

Untitled

a guest
Nov 20th, 2017
66
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.25 KB | None | 0 0
  1. CREATE PROCEDURE [dbo].[sp_GL_Prop_SecAgent_MtMValue_Profit_EndOfMonth_CleanPrice]
  2.  
  3. @BookingID varchar(32),
  4.  
  5. @Date datetime,
  6.  
  7. @LastDate datetime,
  8.  
  9. @Value float output
  10.  
  11. AS
  12.  
  13. if datediff(m, @LastDate, @Date) = 0
  14.  
  15. select @Value = 0
  16.  
  17. else
  18.  
  19. begin
  20.  
  21. declare @AgentTicket varchar(10),
  22.  
  23. @Ticket varchar(10),
  24.  
  25. @AmortisedCost float,
  26.  
  27. @SecInfoCurrency varchar(3),
  28.  
  29. @LastDayOfMonth datetime
  30.  
  31.  
  32.  
  33. set @Value = 0
  34.  
  35. select @AgentTicket = Ticket from GL_Transaction where BookingId = @BookingID
  36.  
  37. select @LastDayOfMonth = dbo.f_LastDayOfMonth(@LastDate)
  38.  
  39.  
  40.  
  41. declare si_cursor cursor
  42.  
  43. for select Ticket, abs(AmortisedCost), Currency from v_Security_Info where Agent = @AgentTicket and [Date] = @LastDayOfMonth
  44.  
  45. open si_cursor
  46.  
  47. fetch next from si_cursor into @Ticket, @AmortisedCost, @SecInfoCurrency
  48.  
  49.  
  50.  
  51. while @@FETCH_STATUS = 0
  52.  
  53. begin
  54.  
  55. --ma kapjuk meg a tegnapi valós értéket, ezért a tegnapi napra mentett valós értéket kell könyvelnünk
  56.  
  57. --BB-ben csak minden hónap végén könyvelünk valós értéket, tehát az eljárásnak csak a hónap első könyvelési napján kell visszaadnia az előző hónap utolsó napjára számolt valós értéket
  58.  
  59. declare @ValueId int
  60.  
  61. ,@MtmValue float
  62.  
  63. ,@Rate float
  64.  
  65. ,@Currency varchar(3)
  66.  
  67.  
  68.  
  69. --Amortised cost forintosítás - ritkán lehet rá szükség, de előfordulhat
  70.  
  71. if @SecInfoCurrency != 'HUF'
  72.  
  73. begin
  74.  
  75. select @Rate = dbo.f_Get_Last_GL_Reval_Rate(@SecInfoCurrency, @LastDayOfMonth)
  76.  
  77.  
  78.  
  79. if dbo.f_Currency_RateOrder('HUF') > dbo.f_Currency_RateOrder(@SecInfoCurrency)
  80.  
  81. select @AmortisedCost = @AmortisedCost * @Rate
  82.  
  83. else
  84.  
  85. select @AmortisedCost = @AmortisedCost / @Rate
  86.  
  87. end
  88.  
  89.  
  90.  
  91. --az MtMValues táblából kellene az ügylethez tartozó SumMtMValue oszlop értéke
  92.  
  93. --ha egy napon többször is mentettek valós értéket, akkor a legutolsó mentett valós értéket vegye ki: MtMSaved legutolsó id-hoz tartozó MtmValue érték
  94.  
  95. select @ValueId = max(ValueId)
  96.  
  97. from MtMSaved
  98.  
  99. where ValueDate = @LastDayOfMonth
  100.  
  101.  
  102.  
  103. select @MtmValue = isnull(sum(MtMValue-Interest),0)
  104.  
  105. ,@Currency = Currency
  106.  
  107. from Mtmvalues
  108.  
  109. where Ticket = @Ticket
  110.  
  111. and Id = @ValueId
  112.  
  113. group by Ticket, Currency
  114.  
  115.  
  116.  
  117. --amennyiben nem forintban mentették le a valós értéket, akkor a legutolsó MNB közép árfolyammal forintosítsuk ezt az értéket
  118.  
  119. if @Currency != 'HUF'
  120.  
  121. begin
  122.  
  123. select @Rate = dbo.f_Get_Last_GL_Reval_Rate(@Currency, @LastDayOfMonth)
  124.  
  125.  
  126.  
  127. if dbo.f_Currency_RateOrder('HUF') > dbo.f_Currency_RateOrder(@Currency)
  128.  
  129. select @MtmValue = @MtmValue * @Rate
  130.  
  131. else
  132.  
  133. select @MtmValue = @MtmValue / @Rate
  134.  
  135. end
  136.  
  137.  
  138.  
  139. --Az agent minden ügyletére összeadjuk az (amortisedcost - clean price) különbséget
  140.  
  141. select @Value = @Value + @AmortisedCost - @MtmValue
  142.  
  143.  
  144.  
  145. fetch next from si_cursor into @Ticket, @AmortisedCost, @SecInfoCurrency
  146.  
  147. end
  148.  
  149. close si_cursor
  150.  
  151. deallocate si_cursor
  152.  
  153.  
  154.  
  155. --az eljárás csak akkor adjon vissza értéket, ha a SumMtmValue > 0, különben nullát adjon vissza
  156.  
  157. if @Value < 0
  158.  
  159. select @Value = 0
  160.  
  161.  
  162.  
  163. end
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement