DBNull.Value 强制转换为类型“System.DateTime”。请使用可空类型
2010-12-16 10:29
501 查看
(1)
转取数据库中的数据时,数据库中的字段有可能是空值,虽然Linq中的Field方法和SetField方法都可以处理可以为 null 的类型,不必像前面的示例那样检查 Null 值,我们再用Field将一些可空的值赋给实体的属性时,有可能会报错,因为实体的属性是可空类型,例如: 角色(SmRole)实体有如下可空类型的创建时间的属性 public virtual DateTime? Createdtime { get { return _createdtime; } set { _bIsChanged |= (_createdtime != value); _createdtime = value; } } //dsRole为数据集 var roleAllDs = from role in dsRole.Tables[0].AsEnumerable() select role; //创建SmRole实体对象 SmRole smrole = new SmRole(); //遍历数据 foreach (var r in roleAllDs)//dsRole.Tables[0].Rows { //... //smrole.Createdtime = r.Field("CREATEDTIME"); //如上这样取值就会报标题所示的异常,应该改为可空类型,正确的如下 smrole.Createdtime = r.Field("CREATEDTIME");//加上可空标识 //... }
转
(2)
无法将 NULL 转换成“System.DateTime”,因为它是一种值类型
在C# 2.0里面的数据类型中,分为值类型和引用类型,引用类型可以初始化为null,可是值类型是不可以的。
比如经常用到的System.Guid类型,要么赋值为Guid.NewId,要么赋值为Guid.Empty。
再比如System.DateTime,默认初始化为DateTime.MinValue。
强行给值类型赋null值,编译就不会通过,会报出类似下面的异常:
错误 1 无法将 NULL 转换成“System.DateTime”,因为它是一种值类型
这个时候就要借助Nullable<T>结构体了。
拿DateTime举例,完整的写法:
Nullable<DateTime> now = DateTime.Now;
Nullable<DateTime> now = null;
当然也可以缩写:
DateTime? now = DateTime.Now;
DateTime? now = null;
我们可以直接对now赋值,但实际上是给now.Value赋值。
既然可以为空,就涉及到判断了,以下两种方式都是可行的:
if (now != null) {}
if (now.HasValue()) {}
if (now == null) {
DateTime.MinValue;
}
有一点需要注意的是,值类型可以通过这种方法变成引用类型,但是引用类型不可以哟。比如下面这段代码:
Nullable<string> test = "ddd";
这段代码编译无法通过,会报出以下异常:
错误 1 类型“string”必须是不可为空的值类型才能用作泛型类型或方法“System.Nullable<T>”中的参数“T”
(3)
System.Data.StrongTypingException===》如果是在.xsd文件中创建datatable或dataadapter的,有日期格式的话,要在日期字段的属性中设置属性defaultvalue设置“1/1/0001 12:00:00 AM",nullValue 设置为0001-01-01T00:00:00.0000000
转取数据库中的数据时,数据库中的字段有可能是空值,虽然Linq中的Field方法和SetField方法都可以处理可以为 null 的类型,不必像前面的示例那样检查 Null 值,我们再用Field将一些可空的值赋给实体的属性时,有可能会报错,因为实体的属性是可空类型,例如: 角色(SmRole)实体有如下可空类型的创建时间的属性 public virtual DateTime? Createdtime { get { return _createdtime; } set { _bIsChanged |= (_createdtime != value); _createdtime = value; } } //dsRole为数据集 var roleAllDs = from role in dsRole.Tables[0].AsEnumerable() select role; //创建SmRole实体对象 SmRole smrole = new SmRole(); //遍历数据 foreach (var r in roleAllDs)//dsRole.Tables[0].Rows { //... //smrole.Createdtime = r.Field("CREATEDTIME"); //如上这样取值就会报标题所示的异常,应该改为可空类型,正确的如下 smrole.Createdtime = r.Field("CREATEDTIME");//加上可空标识 //... }
转
(2)
无法将 NULL 转换成“System.DateTime”,因为它是一种值类型
在C# 2.0里面的数据类型中,分为值类型和引用类型,引用类型可以初始化为null,可是值类型是不可以的。
比如经常用到的System.Guid类型,要么赋值为Guid.NewId,要么赋值为Guid.Empty。
再比如System.DateTime,默认初始化为DateTime.MinValue。
强行给值类型赋null值,编译就不会通过,会报出类似下面的异常:
错误 1 无法将 NULL 转换成“System.DateTime”,因为它是一种值类型
这个时候就要借助Nullable<T>结构体了。
拿DateTime举例,完整的写法:
Nullable<DateTime> now = DateTime.Now;
Nullable<DateTime> now = null;
当然也可以缩写:
DateTime? now = DateTime.Now;
DateTime? now = null;
我们可以直接对now赋值,但实际上是给now.Value赋值。
既然可以为空,就涉及到判断了,以下两种方式都是可行的:
if (now != null) {}
if (now.HasValue()) {}
if (now == null) {
DateTime.MinValue;
}
有一点需要注意的是,值类型可以通过这种方法变成引用类型,但是引用类型不可以哟。比如下面这段代码:
Nullable<string> test = "ddd";
这段代码编译无法通过,会报出以下异常:
错误 1 类型“string”必须是不可为空的值类型才能用作泛型类型或方法“System.Nullable<T>”中的参数“T”
(3)
System.Data.StrongTypingException===》如果是在.xsd文件中创建datatable或dataadapter的,有日期格式的话,要在日期字段的属性中设置属性defaultvalue设置“1/1/0001 12:00:00 AM",nullValue 设置为0001-01-01T00:00:00.0000000
相关文章推荐
- 无法将 DBNull.Value 强制转换为类型“System.DateTime”。请使用可空类型
- 从EXCEL导入文件时无法将DBNull.Value强制转换为类型。。。,请使用可空类型 问题的解决
- 无法将类型为“System.DBNull”的对象强制转换为类型“System.Byte[]”
- c#:无法将类型为“System.DBNull”的对象强制转换为类型“System.String”
- 无法将类型为“System.DBNull”的对象强制转换为类型“System.String”
- NotSupportedException-无法将类型“System.DateTime”强制转换为类型“System.Object”
- C#.NET开发Winform使用MySQL数据库 无法将“System.Byte[]”的对象强制转换为类型“System.IConvertible”
- 无法将类型为“System.DBNull”的对象强制转换为类型“System.String”。
- 无法将类型为“System.DBNull”的对象强制转换为类型“System.String”分析及解决方案
- NotSupportedException-无法将类型“System.DateTime”强制转换为类型“System.Object”
- 错误:无法将类型为“System.DBNull”的对象强制转换为类型“System.Byte[]”。
- C# 无法将类型为“System.DBNull”的对象强制转换为类型“System.String”。
- ASP.NET.MVC异常--无法将类型为System.Int32的对象强制转换为类型System.String
- 急!delphi中variant能否和object类型转换。实例:在使用getpropvalue(range,'属性')时提示类型有错,如何解决?!!
- 无法将类型为“IList”的对象强制转换为类型“System.Data.DataRowView” 。的解决方法
- C#中使用System.Convert类将一种基础数据类型转换为其他基础数据类型
- 不允许从数据类型 datetime 到数据类型 int 的隐性转换(表 'tempdb.dbo.#3884BFB0',列 'IsNominate')。请使用 CONVERT
- 在使用EF开发时候,遇到 using语句中使用的类型必须可隐式转换为System.IDisposE
- 无法将类型为“System.__ComObject”的 COM 对象强制转换为接口类型“Microsoft.VisualStudio.Tools.Applications.Runtime.IHostServiceProvider”
- System.InvalidCastException: 对象不能从 DBNull 转换为其他类型。