gpt4 book ai didi

c# - 使用 Dapper 从 MySql 映射日期字段时出现 InvalidCastException

转载 作者:可可西里 更新时间:2023-11-01 07:53:40 25 4
gpt4 key购买 nike

我刚刚开始使用 Dapper 访问 MySql 数据库,我似乎在处理日期字段时遇到了问题。每当我尝试映射 MySql 日期类型字段时,我都会收到无效的转换。似乎 MySql 连接器正在返回一个 MySqlDateTime 类型,这导致 Dapper 将其转换为对象而不是日期时间。这是相关代码

我模型上的属性定义

public DateTime PickupDate { get; set; }

MySql 中的字段定义

PickupDate DATE

抛出异常

System.Data.DataException : Error parsing column 1 (PickupDate= - Object)
----> System.InvalidCastException : Specified cast is not valid.

我知道这一定是我遗漏的东西,任何人都可以指出我需要做什么才能让 dapper 将此字段映射到 DateTime 数据类型的正确方向吗?

最佳答案

答案是在连接字符串中将 AllowZeroDateTime 设置为 false。从 MySql 连接字符串选项文档中找到 here .

If set to True, MySqlDataReader.GetValue() returns a MySqlDateTime object for date or datetime columns that have disallowed values, such as zero datetime values, and a System.DateTime object for valid values. If set to False (the default setting) it causes a System.DateTime object to be returned for all valid values and an exception to be thrown for disallowed values, such as zero datetime values.

出于某种原因,即使日期有效,我得到的是 MySqlDateTime 类型而不是 DateTime。将此更改为 false 会导致发生正确的行为。

关于c# - 使用 Dapper 从 MySql 映射日期字段时出现 InvalidCastException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11711016/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com