检索 MySQL 日期时,它变为日期和时间

Posted

技术标签:

【中文标题】检索 MySQL 日期时,它变为日期和时间【英文标题】:When retrieving MySQL date, it becomes date and time 【发布时间】:2020-03-20 07:20:33 【问题描述】:

我想问一下为什么当我从数据库中检索数据时,日期变成了日期和时间。

这是我的数据库:

这是我的 C# 代码:

private void runQuery()

    string query = txtQuery.Text;

    if(query == "")
    
        MessageBox.Show("Empty Query");
        return;
    

    string strSQLConnection = "datasource = 127.0.0.1;port = 3306; username = root; password =; database =inventory";
    mysqlConnection dbConnection = new MySqlConnection(strSQLConnection);
    MySqlCommand sqlCmd = new MySqlCommand(query, dbConnection);
    sqlCmd.CommandTimeout = 60;

    try
    
        dbConnection.Open();

        MySqlDataReader myReader = sqlCmd.ExecuteReader();

        if(myReader.HasRows)
        
            while(myReader.Read())
            
                lstQuery.Items.Add(myReader.GetString(0) + " | " + myReader.GetString(1) +" | " + myReader.GetString(2));
            
        
        else
        
            lstQuery.Items.Add("Query successfully executed!");
        
    
    catch(Exception e)
    
        MessageBox.Show("Query error: " + e.Message);
    

输出:

数据库:

【问题讨论】:

我不确定我遗漏了哪些信息,请告诉我,我会添加它。谢谢。 【参考方案1】:

在 .NET 中,没有仅日期类型。处理日期值的类型称为DateTime,它代表日期和时间。因此,当您从数据库中检索日期值时,它会转换为 DateTime 值,时间部分为 00:00:00,然后通过 GetString() 方法转换为字符串。你应该做的是使用DateTime.ToString() 来格式化你喜欢的日期。

试试这样的:

string formattedDate = myReader.GetDateTime(2).ToString("yyyy-MM-dd");

参考资料:

SqlDataReader.GetDateTime().

DateTime.ToString().

【讨论】:

以上是关于检索 MySQL 日期时,它变为日期和时间的主要内容,如果未能解决你的问题,请参考以下文章

MySQL日期类型

在 Angular 中调用方法时,当前日期变为未定义

CSV 日期格式转 MySQL 日期格式

日期字段在 PHP 和 MySQL 中被重置

如何使用 jdatechooser 从 mysql 数据库中保存和检索空日期

MySQL为每一行自动存储日期时间