DBNull.Value 强制转换为类型“System.DateTime”。请使用可空类型

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值