前言:
今天在机房重构的时候,遇到了这个错误:对象不能从DBnull转换为其他类型
DBNull是什么?
DBNull在DotNet是单独的一个类型 System.DBNull 。它只有一个值 DBNull.Value 。
DBNull直接继承 Object ,所以 DBNull 不是 string , 不是 int , 也不是 DateTime
对象不能从DBnull转换为其他类型是什么意思?
经过百度,知道这个错误是由于我们的数据库中有空值(NULL),而数据库的NULL值在代码中用DBNULL.value表示,不能转成其他类型。
然而我D层从数据库查到这个空值以后,想把它转换成DateTime类型的数据。
解决方法:
1.在数据库中直接设置该列不能为空。
2.先把得到的值进行判断,如果在数据库中为空值的话,给它赋一个值。
if(a == DBnull)
{
a =