从 SQLite 数据库中读取日期时间值,并使用 WPF 将其分配给 C# 中的日期选取器

本文关键字:分配 选取 日期 WPF 取日期 读取 数据库 SQLite 时间 | 更新日期: 2023-09-27 18:34:28

我想从 SQLite 数据库中读取日期时间值并将其分配给日期选取器控件。

这是我的代码:

try
{
    sqlitecon.Open();
    string Query = "Select * from Customer_New where Cust_Id='" + val + "'  ";
    SQLiteCommand createCommand = new SQLiteCommand(Query, sqlitecon);
    //  createCommand.ExecuteNonQuery();
    SQLiteDataReader dr = createCommand.ExecuteReader();
    while(dr.Read()){
        date_open.DisplayDate = Convert.ToDateTime(dr.GetString(0));
        Date_Joining.DisplayDate = Convert.ToDateTime(dr.GetString(1));     
        txt_Title.Text = dr.GetString(3);
        txt_cardnum.Text =dr.GetString(4)          
    }                
    sqlitecon.Close();
}
catch (Exception ex)
{
    MessageBox.Show(ex.Message);
}

但它给出了此错误:"指定的强制转换无效"。怎么能做到呢?

从 SQLite 数据库中读取日期时间值,并使用 WPF 将其分配给 C# 中的日期选取器

如果您已经从数据库中获取了DateTime,则不应将其转换为字符串。然后只需使用:

date_open.DisplayDate = dr.GetDateTime(0);

而不是

date_open.DisplayDate = Convert.ToDateTime(dr.GetString(0));

如果它不是DateTime而是string(varchar(,您应该考虑改变它。

编辑:另请注意,您正在使用查询的两个不同列将数据时间分配给DateTimePicker,因此在上面一行之后,您执行 mthis:

date_open.DisplayDate = Convert.ToDateTime(dr.GetString(1)); 

两者之一必须不正确。哪一列是日期时间列?

此外,您应该参数化查询以避免 sql 注入:

string Query = "Select * from Customer_New where Cust_Id=?1";
command.Parameters.Add(new SQLiteParameter { ParameterName = "1", Value = val }); 

(注意我从来没有用过SqlLite,所以代码是未经测试的(

Select strftime([date],0) as [date] from Customer_New where Cust_Id=?1