我想从SQLite数据库中读取日期时间值并将其分配给datepicker控件。
这是我的代码:
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);
}
但是它给出了这个错误:“指定的强制转换无效”。怎么做到呢?。
答案 0 :(得分:1)
如果您已从数据库中获得DateTime
,则不应将其转换为字符串。然后使用:
date_open.DisplayDate = dr.GetDateTime(0);
而不是
date_open.DisplayDate = Convert.ToDateTime(dr.GetString(0));
如果它不是DateTime
而是string
(varchar
),您应该考虑更改它。
修改:另请注意,您正在使用查询的两个不同列将数据时间分配给DateTimePicker
,因此在上面的行后面,您可以执行以下操作:
date_open.DisplayDate = Convert.ToDateTime(dr.GetString(1));
其中一个必须是不正确的。哪个列是datetime列?
此外,您应该参数化您的查询以避免sql注入:
string Query = "Select * from Customer_New where Cust_Id=?1";
command.Parameters.Add(new SQLiteParameter { ParameterName = "1", Value = val });
(请注意,我从未使用过SqlLite,因此代码未经测试)
答案 1 :(得分:0)
Select strftime([date],0) as [date] from Customer_New where Cust_Id=?1