Mysql BLToolKit:如何获取';空的';日期时间字段?
如果要映射的字段之一具有DateTime字段,并且数据库中的相应值具有“0000-00-00”或“0001-01-01”,则请求执行失败。返回以下错误 无法将MySQL日期/时间值转换为System.DateTime 有没有可能获得这样的价值 我已经尝试将“DateTime”值指定为属性类型-它也没有帮助(实际上,我并不认为这会有帮助)Mysql BLToolKit:如何获取';空的';日期时间字段?,mysql,bltoolkit,Mysql,Bltoolkit,如果要映射的字段之一具有DateTime字段,并且数据库中的相应值具有“0000-00-00”或“0001-01-01”,则请求执行失败。返回以下错误 无法将MySQL日期/时间值转换为System.DateTime 有没有可能获得这样的价值 我已经尝试将“DateTime”值指定为属性类型-它也没有帮助(实际上,我并不认为这会有帮助) 另外,我使用MySql 5.1您尝试过MapValue属性吗?我不确定这是否有效,但是 [MapValue(null, "0000-00-00")] [MapV
另外,我使用MySql 5.1您尝试过MapValue属性吗?我不确定这是否有效,但是
[MapValue(null, "0000-00-00")]
[MapValue(null, "0001-01-01")]
public DateTime? theDate;
您尝试过MapValue属性吗?我不确定这是否有效,但是
[MapValue(null, "0000-00-00")]
[MapValue(null, "0001-01-01")]
public DateTime? theDate;
我在使用NHibernate时遇到了一个类似的问题,在一个异常中出现了相同的错误 这是因为MySQL独特的“特性”允许在日期字段中使用无效日期,特别是使用0000-00-00作为日期非空列的默认值。当遇到这样的日期时,它会在将自身转换为DateTime时引发异常 对此,建议的解决方案是添加 允许零日期时间=真 连接字符串,但实际上这对我不起作用。我最终通过修改连接字符串解决了这个问题 转换为零日期时间=真 所以你的app.config部分看起来像这样
<connectionStrings>
<add
name="ConnectionString.MySql"
connectionString="Server=localhost;Port=3306;Database=BLT;Uid=someuser;Convert Zero DateTime=true;"
providerName="MySql.Data.MySqlClient"/>
我在使用NHibernate时遇到了一个类似的问题,在异常中出现了相同的错误 这是因为MySQL独特的“特性”允许在日期字段中使用无效日期,特别是使用0000-00-00作为日期非空列的默认值。当遇到这样的日期时,它会在将自身转换为DateTime时引发异常 对此,建议的解决方案是添加 允许零日期时间=真 连接字符串,但实际上这对我不起作用。我最终通过修改连接字符串解决了这个问题 转换为零日期时间=真 所以你的app.config部分看起来像这样
<connectionStrings>
<add
name="ConnectionString.MySql"
connectionString="Server=localhost;Port=3306;Database=BLT;Uid=someuser;Convert Zero DateTime=true;"
providerName="MySql.Data.MySqlClient"/>
我认为你必须通过另一个属性来控制它
[MapField("the_date")]
public DateTime? theDate; // Map
[MapIgnore]
public DateTime theDateControl
{
set {
if(theDate.HasValue)
{
....
}
}
}
我认为你必须用另一种财产来控制它
[MapField("the_date")]
public DateTime? theDate; // Map
[MapIgnore]
public DateTime theDateControl
{
set {
if(theDate.HasValue)
{
....
}
}
}