设为首页 收藏本站
查看: 2131|回复: 0

[经验分享] SQL server和C#使用什么类型来记录金额

[复制链接]

尚未签到

发表于 2015-7-5 07:35:54 | 显示全部楼层 |阅读模式
  今天的一个小讨论,关于SQL server和C#使用什么类型来记录金额。
  
  SQL server里的金额表示
  (1)Money类型
  SQL Server里使用Money和smallmoney类型来表示货币类型,Money是8字节的,smallmoney是4字节的。
  如果一个对象被定义为 money,则它最多可以包含 19 位数字,其中小数点后可以有 4 位数字。该对象使用 8 个字节存储数据。因此,money 数据类型的精度是 19,小数位数是 4,长度是 8。
  数据类型
  范围
  长度
  Money
  -922,337,203,685,477.5808 到 922,337,203,685,477.5807
  8字节
  Smallmoney
  214,748.3648 到 214,748.3647
  4字节
  money 和 smallmoney 限制为小数点后有 4 位。如果需要小数点后有更多位,请使用 decimal 数据类型。
  money 或 smallmoney 常量中不允许使用逗号分隔符。只能在显式转换为 money 或 smallmoney 的字符串中指定逗号分隔符。
  实例代码
USE tempdb;

GO

CREATE TABLE Test (num INT PRIMARY KEY, summary MONEY);

GO

SET NOCOUNT ON;

GO


-- 插入数据到临时表

INSERT INTO Test VALUES (1, $123.45);

GO

INSERT INTO Test VALUES (2, $123123.45);

GO

INSERT INTO Test VALUES (3, CAST('$444,123.45' AS MONEY) );

GO


-- 插入错误示例,分隔符是字符串类型

INSERT INTO TestMoney VALUES (3, $555,123.45);

GO

SET NOCOUNT OFF;

GO

SELECT * FROM Test;

GO

--返回错误信息

--Msg 213, Level 16, State 1, Line 3

  --列名或所提供值的数目与表定义不匹配
  
  (2)Decimal类型
  Decimal是带固定精度和小数位数的数值数据类型
decimal[ (p[ , s] )] 和 numeric[ (p[ , s] )]

固定精度和小数位数。使用最大精度时,有效值从 - 10^38 +1 到 10^38 - 1。decimal 的 ISO 同义词为 dec 和 dec(p, s)。numeric 在功能上等价于 decimal。

p(精度)

最多可以存储的十进制数字的总位数,包括小数点左边和右边的位数。该精度必须是从 1 到最大精度 38 之间的值。默认精度为 18。

s (小数位数)

小数点右边可以存储的十进制数字的最大位数。小数位数必须是从 0 到 p 之间的值。仅在指定精度后才可以指定小数位数。默认的小数位数为 0;因此,0

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-83221-1-1.html 上篇帖子: sql server 外键 更新(删除)规则 下篇帖子: SQL SERVER数据库删除LOG文件和清空日志的方案
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表