不知如何用convert转成money型 下边两个正确吗?dr["PremiumNewBase"] = Convert.ToDecimal(Request.Form["PremiumNewBase"]);
dr["PremiumNewBase"] = Convert.ToDouble(Request.Form["PremiumNewBase"]);

解决方案 »

  1.   

    哪个更好些
    是ToDecimal吗?
      

  2.   

    问题补充
    如果数据库有一个字段是float类型的一个字段的类型是money类型的,最后在程序上要有一个对float和money类型的相乘运算,是否是把他们都强制转换成ToDecimal类型,最后再进行相乘运算
      

  3.   

    哪个精度高哪个更好。详情见:
    http://zhidao.baidu.com/question/16735175.html?fr=qrl
      

  4.   

    没有比较过
    不过以前我用的是ToDecimal
      

  5.   

    不用转换,因为你从库里取出来的东西已经是经过库处理,所以误差早已经有了但是计算的结果的类型却发生了变化,他不在是float类型,而是double
      

  6.   

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

  7.   

    再次纠正:
      从库里取出来的float数据,不必进行转换,直接就用float类型
      但是,计算出的结果出现误差,因为float的精确度毕竟比decimal,double小
      
      所以,如果你的数据经过计算以后会出现较大的误差时,先将其转换为Decimal或者double,然后再进行计算,这未尝不是一种好的办法