C# 对象不能从DBnull转换为其他类型

在重构过程中遇到一个错误:对象不能从DBNull转换为其他类型。DBNull是DotNet中的一个独立类型,表示数据库中的NULL值。解决方法包括:1. 设置数据库列不允许为空;2. 先判断值是否为DBNull再转换;3. 使用try/catch处理转换异常。此外,文中还提及了Int32和Int64的数值范围区别。
摘要由CSDN通过智能技术生成

前言:

今天在机房重构的时候,遇到了这个错误:对象不能从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 = 
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值