0

我正在使用下面的代码从包含日期列的 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;
4

2 回答 2

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();
于 2012-04-08T17:02:47.143 回答
0

使用DataGridView.CellFormatting 事件

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;
                }
            }
        }
    }
于 2014-01-02T00:06:36.457 回答