C# 根据日期时间值和 ID 从数据库获取约会

标签 c# mysql datetime nullreferenceexception

我的 WinForm 上有一个月历。当用户单击日期时,我想检查该用户在单击当天是否存在约会,然后显示一些信息。我使用 MySql 连接器在 MySql 数据库中检查此信息。我目前在 Gebruiker_has_Afspraak 表中检查与用户 ID 对应的约会 ID,然后在 Afspraak 表中检查与单击月历上的日期相同的日期。如果相同,它将返回约会的位置(将来会提供更多信息)。

我有这个代码:

 public List<string> checkAfspraakDate(DateTime datum, string type, string id)
    {
        List<string> result = new List<string>();
        List<string> result1 = new List<string>();
        if (this.openConnection() == true)
        {
            //Afspraak_id ophalen uit Gebruiker_has_afspraak
            string query = "SELECT Afspraak_id FROM Gebruiker_has_Afspraak WHERE Gebruiker_id = '" + id + "' ";
            MySqlCommand cmd = new MySqlCommand(query, connection);
            cmd.CommandType = CommandType.Text;
            using (MySqlDataReader reader = cmd.ExecuteReader())
            {
              while (reader.Read())
              {
                result.Add(reader.GetString(0));
              }

              reader.Close();
            }
            cmd.Cancel();
            //Afspraak gegevens uit table halen | Gebaseerd op Afspraak_id^ en datum_today
            foreach (string item in result)
            {
                query = "SELECT afspraak_locatie FROM Afspraak WHERE id = '" + item + "' AND datum = '" + datum +"'";
                MySqlCommand cmd1 = new MySqlCommand(query, connection);
                cmd1.CommandType = CommandType.Text;
                using (MySqlDataReader reader1 = cmd1.ExecuteReader())
                {
                    while (reader1.Read())
                    {
                        result1.Add(reader1.GetString(0));
                    }

                    reader1.Close();
                }
                cmd1.Cancel();
            }
            return result1;

        }
        else
        {
            return result;
        }
    }

如果当前用户 ID 与表中的用户 ID 匹配,第一个代码将从表“Gebruiker_has_Afspraak”中提取“Afspraak_id”。

然后,“Afspraak_id”将用于检查“Afspraak”表中的约会,其中日期 == 月历上单击的日期。

我当前正在尝试将 DateTime 对象与数据库中的日期进行比较,因为数据库中的日期存储为日期时间值。 我也用一根绳子尝试过,但也不起作用。我在 'while(reader1.Read())' 部分收到 system.NullReferenceException 。我认为这是因为我从数据库中得到了一个空值,但这是不对的,因为几乎所有日期都有约会。

最佳答案

由于您将 C# DateTime 对象与字符串连接,这将导致在该对象上调用默认的 .ToString() 。这取决于它所运行的 PC/服务器的文化以及返回的格式。

由于 MySQL 的格式为 YYYY-MM-DD HH:MM:SS,这可能会有所不同,因此不会导致匹配。您需要调用datum.ToString("yyyy-MM-dd HH:mm:ss")

请记住,您的检查还将检查直至秒数的日期是否匹配,您可能只想检查日期部分。

关于C# 根据日期时间值和 ID 从数据库获取约会,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37918717/

相关文章:

c# - EF : When executing a command, 参数必须完全是数据库参数或值

c# - 使用 SetupDiGetDriverInfoDetail 调用 PInvoke

mysql给出不推荐使用的警告

java - 无法将字符串解析为 Java 8 LocalDateTime

使用 DateTime.date 的 C# MongoDb 项目

c# - 如何使用带有多个参数的 C# 运行 cmd.exe?

c# - 如何以编程方式将 Word 文件转换为 PDF?

java - 将 jspinner 时间值插入数据库

mysql - 在 mysql 中选择长文本列太慢

c# - 一周中天数的系统常量 (7)