通过从DateTimePicker获取日期从数据库获取数据

时间:2016-06-20 10:48:41

标签: c# sql sql-server

我试图根据在dateTimePicker中输入的日期在gridview中获取数据。但是,如果我使用equals函数来比较两个字符串的条件,我会得到null引用运行时错误。

ReportFrom.cs

private void button1_Click(object sender, EventArgs e)
{
        string date = dateTimePicker.Value.ToShortDateString();
        reportLayer.MakeDailyReport(date, dataGridViewReport);
}

ReportLayer.cs

private SqlConnection con = new SqlConnection("Data Source=CHAMP-PC;Initial Catalog=ProcessSale;Integrated Security=True");
private SqlCommand cmd;
private SqlDataAdapter adapt;

public void MakeDailyReport(string givenDate, DataGridView view)
{
    try
    {
        con.Open();

        DataTable dt = new DataTable();

        cmd = new SqlCommand("SELECT Date FROM FinalSales where Date = @datePicker", con);
        cmd.Parameters.AddWithValue("@datePicker", givenDate);

        cmd.ExecuteNonQuery();

        object dateObject = cmd.ExecuteScalar();

        string dateObjectstring = Convert.ToString(dateObject);
        string givenDateString = Convert.ToString(givenDate);
        // string DBdate = dateObject.ToString();

        if (dateObject.Equals(givenDate))
        {
            adapt = new SqlDataAdapter("SELECT Date FROM FinalSales where Date = " + givenDate + "", con);

            if (adapt != null)
            { 
                adapt.Fill(dt);

                view.DataSource = dt;
            }
            else
            {
                MessageBox.Show("No Record found againts that date");
                con.Close();
            }
        }
        else
        {
            con.Close();
        }
    }
    catch (Exception a)
    {
        MessageBox.Show(a.Message);
        con.Close();
    } 
}

1 个答案:

答案 0 :(得分:1)

看看这里: Handling ExecuteScalar() when no results are returned

此外:小心调用Equals()。目前你正在比较 两个字符串。一个具有ShortDate值的一个具有默认的ToString()。

如果日期相同,则可能返回false。

更好的解决方案是将这两个值作为DateTime处理并使用==运算符。

托马斯

相关问题