请教一个MONEY类型的数据保存问题

isitor 2008-04-09 09:11:59
不知如何用convert转成money型 下边两个正确吗?

dr["PremiumNewBase"] = Convert.ToDecimal(Request.Form["PremiumNewBase"]);

dr["PremiumNewBase"] = Convert.ToDouble(Request.Form["PremiumNewBase"]);


...全文
140 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
JL99000 2008-04-09
  • 打赏
  • 举报
回复
再次纠正:
从库里取出来的float数据,不必进行转换,直接就用float类型
但是,计算出的结果出现误差,因为float的精确度毕竟比decimal,double小

所以,如果你的数据经过计算以后会出现较大的误差时,先将其转换为Decimal或者double,然后再进行计算,这未尝不是一种好的办法


JL99000 2008-04-09
  • 打赏
  • 举报
回复
上面的解释错误
改正,数据库里存放float类型时,其位数可以多余一个
而。NET中受限制,因此应该将从库里取出的数据转换为Decimal或者double

JL99000 2008-04-09
  • 打赏
  • 举报
回复
不用转换,因为你从库里取出来的东西已经是经过库处理,所以误差早已经有了

但是计算的结果的类型却发生了变化,他不在是float类型,而是double
  • 打赏
  • 举报
回复
没有比较过
不过以前我用的是ToDecimal
chenhaoying 2008-04-09
  • 打赏
  • 举报
回复
哪个精度高哪个更好。详情见:
http://zhidao.baidu.com/question/16735175.html?fr=qrl
isitor 2008-04-09
  • 打赏
  • 举报
回复
问题补充
如果数据库有一个字段是float类型的一个字段的类型是money类型的,最后在程序上要有一个对float和money类型的相乘运算,是否是把他们都强制转换成ToDecimal类型,最后再进行相乘运算
JL99000 2008-04-09
  • 打赏
  • 举报
回复
只要是数值类型的就可以

到数据库里会做处理,将精确到它们所代表的货币单位的万分之一

isitor 2008-04-09
  • 打赏
  • 举报
回复
哪个更好些
是ToDecimal吗?
chenhaoying 2008-04-09
  • 打赏
  • 举报
回复
两个都能存进去。

62,051

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧