ExecuteScalar()方法返回值 及 DBnull和NUll的区别

本文详细介绍了cmd.ExecuteScalar()方法的返回值类型及应用场景。当查询结果为空时返回NULL,查询的第一行第一列值为NULL时返回DBNull。DBNull和NULL在概念上有所区别,DBNull用于表示从数据库读取的NULL值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

cmd.ExecuteScalar()方法返回值类型为object

当查询没有任何返回值时会返回Null,表现为直接在SQL Management Studio内查询,没有返回值,为空白。则ExecuteScalar()返回NULL值

当查询有返回值,如果第一行第一列值为NULL,表现为直接在SQL Management Studio内查询,显示为NULL,则ExecuteScalar()返回DBNull值

 

DBNull.ToString()为空字符串,NULL.ToString()会报异常。所以最好先对返回值 进行判断是否为空再作处理。

 

DBNull 和 NULL的区别

 

null是C#中的关键字,表示此引用不指向任何地址。

DBNull只是一个普通的类,继承自object,没添加任何方法属性,其有一个唯一的实例Value。它的存在仅仅只是为了表示从数据库读取数据时遇到的数据库中的null值。

 

可以用Convert.IsDBNull()方法判断是不是DBNull

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值