如何在if条件中应用==十进制值?

时间:2018-08-19 17:42:32

标签: c# operators c#-6.0

这是我一直在尝试执行的逻辑,但是它却带来了问题:

protected void Price_Update_Click(object sender, EventArgs e)
{
    decimal Price;   
    var gvr   = (GridViewRow)(sender as Control).Parent.Parent;
    int index = gvr.RowIndex;
    var box1  = (TextBox)GridView1.Rows[index].Cells[4].FindControl("TextBox1");
    bool prc  = decimal.TryParse(box1.Text, out Price);
    var PriceString = GridView1.Rows[index].Cells[4].Text.Replace(" AUD", "");

    var btn = (Button)sender;
    var row = (GridViewRow)btn.NamingContainer;
    var ProductNo = row.Cells[0].Text;
    var BranchNo  = row.Cells[6].Text;

    if (Price > 00.00)
    {
        var CS  = "data source=LAPTOP-ODS96MIK\\MSSQL2014; database = Grocery_Demo; integrated security=SSPI";
        var con = new SqlConnection(CS);
        var cmd = new SqlCommand("UpdateProductQuantity", con);

        cmd.CommandType = System.Data.CommandType.StoredProcedure;
        con.Open();
        cmd.Parameters.AddWithValue("@ProductPrice", Price);
        cmd.Parameters.AddWithValue("@ProductNo", ProductNo);
        cmd.Parameters.AddWithValue("@GroceryBranchNo", BranchNo);
        cmd.ExecuteNonQuery();
        con.Close();

        MessageBox("Price has been updated");
        DisplayProducts();
    }
    else if (Price == 00.00 || prc == false)
    {
        Label5.Text = "Please don't keep the price blank";
        DisplayProducts();
    }
}

我面临的问题是,在if条件下都有红线,并且说:

  

运算符'>'不能应用于'decimal'和'double'类型的操作数

我仍然不知道我错过了什么窍门。

如果提供适当的语法解决方案,将会很有帮助。

1 个答案:

答案 0 :(得分:4)

简而言之,您无法使用==doubledecimal之间进行比较。

Console.WriteLine((00.00).GetType()); // type is double

我们可以看到00.00的类型为double,但是您的Price的值为decimal类型,因此无法进行比较。

您需要在数字末尾添加或M,因为00.00表示该值为doublem可以使其变为小数。

decimal

  

如果要将数字实数文字视为十进制,请使用后缀m或M

if (Price > 00.00m)