技術(shù) 點(diǎn)
- 技術(shù)
- 點(diǎn)
- V幣
- 點(diǎn)
- 積分
- 21536
|
本帖最后由 todaynew 于 2015-2-7 18:03 編輯
有一個(gè)版友最近在折騰會(huì)計(jì)科目之間的計(jì)算問題,零零碎碎發(fā)了很多的帖子。今天看到一個(gè)關(guān)于費(fèi)用和利潤(rùn)算法的問題,便覺得算法上有些羅嗦,便私下里想找一個(gè)更為簡(jiǎn)單一些的算法。
我們知道會(huì)計(jì)采用借貸記賬法,其中資產(chǎn)、成本及費(fèi)用類科目增加計(jì)入借方,減少計(jì)入貸方,而負(fù)債、權(quán)益、收入類科目相反,并以此實(shí)現(xiàn)借貸平衡。這樣就在計(jì)算期末余額的絕對(duì)值上,會(huì)出現(xiàn)前一類科目的計(jì)算公式與后一類科目的計(jì)算公式中,出現(xiàn)正負(fù)號(hào)相反的問題。比如,計(jì)算應(yīng)收賬款和應(yīng)付賬款的期末余額,計(jì)算公式分別如下:
應(yīng)收賬款期末余額=期初余額+借方發(fā)生額合計(jì)-貸方發(fā)生額合計(jì)
應(yīng)付賬款期末余額=期初余額-借方發(fā)生額合計(jì)+貸方發(fā)生額合計(jì)
假設(shè)我們有一個(gè)查詢中存在這樣幾個(gè)字段:科目編號(hào),科目名稱,類型(True/False),期初余額,借方發(fā)生額合計(jì),貸方發(fā)生額合計(jì),其中類型為True表示資產(chǎn)、成本及費(fèi)用類科目,為False表示負(fù)債、權(quán)益、收入類科目。那么我們求期末余額的話,是可以這樣來寫的:
select *,iif(類型=True,期初余額+借方發(fā)生額合計(jì)-貸方發(fā)生額合計(jì),期初余額-借方發(fā)生額合計(jì)+貸方發(fā)生額合計(jì)) as 期末余額
from 查詢1
問題在于,我們是否一定需要用iif函數(shù)呢?我想應(yīng)該可以不用。因?yàn)槲覀冎涝贏ccess中,True=-1,F(xiàn)alse=0,如果能利用布爾值的這個(gè)特性,那就可以簡(jiǎn)化算法,F(xiàn)在的問題是需要將數(shù)組{-1,0},變換為{-1,1},只要這個(gè)變換能實(shí)現(xiàn),那么就可以容易的寫出算式了。我們可以這樣來變換:
2×{-1,0} => {2×(-1),2×0} => {-2,0}+1 => {-2+1,0+1} => {-1,1} 也就是說: 2×{-1,0}+1 => {-1,1}
基于這樣的變換,我們的查詢就可以簡(jiǎn)化為:
select *,期初余額+(貸方發(fā)生額合計(jì)-借方發(fā)生額合計(jì))*(類型*2+1) as 期末余額
from 查詢1
我是比較討厭用iif函數(shù)的,所以通常遇到iif函數(shù),我就試圖轉(zhuǎn)換一個(gè)算法來解決問題,這種轉(zhuǎn)換我覺得很有趣味。
|
|