我在SQLite3数据库中填充程序中的数据网格视图,该数据库包含使用下面代码的日期列
此日期列存储在Unix时间内,我希望将其显示为正常日期
当我将数据库读入数据网格视图时,有没有办法可以做到这一点?
SQLiteConnectionStringBuilder csb = new SQLiteConnectionStringBuilder();
csb.DataSource = Path.Combine(connectionPath, "sms.db");
SQLiteConnection connection = new SQLiteConnection(csb.ConnectionString);
connection.Open();
// SQL query to read the data fromt he database
SQLiteCommand command = connection.CreateCommand();
//Read Everything
string query = "SELECT * FROM message";
command.CommandText = query;
SQLiteDataAdapter dataAdaptor = new SQLiteDataAdapter(command);
DataSet dataset = new DataSet();
dataAdaptor.Fill(dataset, "Messages");
// Get the table from the data set
DataTable datatable = dataset.Tables["Messages"];
dataGridSMS.DataSource = datatable;
答案 0 :(得分:3)
// This is an example of a UNIX timestamp for the date/time
double timestamp = 1116641532;
// First make a System.DateTime equivalent to the UNIX Epoch.
System.DateTime dateTime = new System.DateTime(1970, 1, 1, 0, 0, 0, 0);
// Add the number of seconds in UNIX timestamp to be converted.
dateTime = dateTime.AddSeconds(timestamp).ToLocalTime();
答案 1 :(得分:0)
使用DataGridView.CellFormatting Event
private void dataGridSMS_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
{
if (this.dataGridSMS.Columns[e.ColumnIndex].Name == "dateColumn")
{
if (e.Value != null)
{
try
{
// Formatting
double timestamp = Convert.ToDouble(e.Value); // if e.Value is string you must parse
System.DateTime dateTime = new System.DateTime(1970, 1, 1, 0, 0, 0, 0);
dateTime = dateTime.AddSeconds(timestamp).ToLocalTime();
e.Value = dateTime.ToString();
e.FormattingApplied = true;
}
catch (Exception)
{
e.FormattingApplied = false;
}
}
}
}