在小數列中儲存金錢:精確度和小數位考量
資料庫設計者經常面臨為小數選擇適當的精確度和小數位的困境用於儲存貨幣值的列。本文探討了所涉及的注意事項,並深入了解了不同場景的最佳值。
高效儲存的精確度和規模
雖然固定寬度的字元列可以提高效率好處,小數列也有其優點。然而,精度和小數位數並不一定越低,儲存效率就越高。
建議的精確度和小數位數
對於一般用途,DECIMAL(19, 4)是普遍接受的選擇。這源自於 VBA/Access/Jet 中的歷史貨幣資料類型以及支援銀行捨去的需要,從而允許自訂舍入演算法。
過度殺傷還是不夠?
DECIMAL(24,8) 對於大多數貨幣應用程式來說似乎過多,因為大多數貨幣的報價都帶有四位或五位小數。在需要擴展精度的場景中,建議考慮浮點類型,因為它們可以處理更廣泛的值。
會計規則和注意事項
To為了確保準確性和合規性,諮詢領域專家和會計準則至關重要。不同的司法管轄區可能對貨幣價值的捨入和精度有具體規定。例如,歐盟國家內傳輸可能規定使用 DECIMAL(p,6) 進行儲存。
避免 SQL Server 的 MONEY 資料型別
MONEY 資料型別SQL Server 中存在已知的準確度與捨去問題。相反,建議使用 DECIMAL 資料類型以獲得最佳精度和可攜性。
銀行家捨入的歷史背景
銀行家捨入廣泛用於計算中,因為它被納入 IEEE 標準並受到數學家的青睞。它通常被稱為“計算機規則”,起源於人類計算實踐。
以上是在小數列中儲存貨幣時應該使用什麼精確度和比例?的詳細內容。更多資訊請關注PHP中文網其他相關文章!