日期:2014-05-18  浏览次数:20679 次

如何处理decimal类型或者money类型的小数位数
存储过程:
----------------------------------------
ALTER PROCEDURE [dbo].[QueryPrice]
@NAME varchar(50)
,@PRICE decimal(18,2) OUTPUT
AS
BEGIN
SET @PRICE = (SELECT PRICE FROM INFO WHERE NAME =@NAME)
END
---------------------------------------

Form内调用:
--------------------------------------------
  connection.Open();
  SqlCommand command = new SqlCommand();
  command.Connection = connection;
  command.CommandText = "QueryPrice";
  command.CommandType = CommandType.StoredProcedure;
  command.Parameters.AddWithValue("@NAME", comboName.Text);  
  command.Parameters.Add("@PRICE", SqlDbType.Decimal).Direction = ParameterDirection.Output;
  command.ExecuteNonQuery();
  textPrice.Text = command.Parameters["@PRICE"].Value.ToString();
  connection.Close();
--------------------------------------------------

问题:
为什么textPrice.Text (TextBox控件)显示不了小数部分,如何显示小数部分。

另外说明,我原来PRICE在数据库中是使用money类型,但小数位一直是4位,不知道怎么调整成2位,按上面相同的方法处理,textPrice.Text也是显示4位小数。

谢谢!












------解决方案--------------------
楼主你在程序中用断点跟踪一下这个command.Parameters["@PRICE"].Value.ToString()
有木有小数点
------解决方案--------------------
SQL code

ALTER PROCEDURE [dbo].[QueryPrice]
@NAME varchar(50)
,@PRICE decimal(18,2) OUTPUT
AS
BEGIN
SET @PRICE = (SELECT round(PRICE,2) FROM INFO WHERE NAME =@NAME)
END