Reader循环不适用于字符串中的参数

时间:2018-10-25 21:49:31

标签: c# sql winforms parameters sqldatareader

我正在尝试以不同的货币显示数据库中的帐户余额。基于comboBox索引,currencyValue会更改。问题在于查询字符串程序中的参数currencyValue永远不会进入while(reader.Read())循环。仅带参数。当我只在字符串中使用神奇的数字(例如4.30)时,它可以很好地工作,但是使用将值设置为4.30的参数不会发生任何反应(仅适用于1)。

private void btnWybierz_Click(object sender, EventArgs e)
    {
        string fullname = cmbKonto.Text;

        string query = string.Format("SELECT CAST(balance / '{0}' AS DECIMAL(10, 2)) " +
                                            "FROM dbo.Accounts " +
                                            "WHERE (firstname + ' ' + lastname)='{1}'", currencyValue, fullname);

        using (SqlConnection connection = ConnectToDB.ConnectDB())
        {
            using (SqlCommand command = new SqlCommand(query, connection))
            {
                using (var reader = command.ExecuteReader())
                {
                    if (reader.HasRows)
                    {
                        while (reader.Read())
                        {
                            saldo = reader[0];
                            tbSaldo.Text = saldo.ToString();
                        }
                    }
                }
            }
        }
    }

1 个答案:

答案 0 :(得分:4)

可以通过将小数位写为4/30来解决此问题。

此问题可以通过用{0}替换'{0}'来解决