您的位置:首页 > 产品设计 > UI/UE

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐