Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/70.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/powerbi/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql BLToolKit:如何获取';空的';日期时间字段?_Mysql_Bltoolkit - Fatal编程技术网

Mysql BLToolKit:如何获取';空的';日期时间字段?

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

如果要映射的字段之一具有DateTime字段,并且数据库中的相应值具有“0000-00-00”或“0001-01-01”,则请求执行失败。返回以下错误

无法将MySQL日期/时间值转换为System.DateTime

有没有可能获得这样的价值

我已经尝试将“DateTime”值指定为属性类型-它也没有帮助(实际上,我并不认为这会有帮助)


另外,我使用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)
         {
            ....
         }
     }
 }