(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)
在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()) {}
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