代码改变世界

ExecuteScaler的三种返回值。

  Ivony...  阅读(1652)  评论(1编辑  收藏  举报
DbCommand.ExecuteScaler在执行的时候,有三种可能的返回值:

1、返回一个object对象,表示有结果,返回的是第一个结果集的首航首列。
2、返回一个DBNull对象,表示有结果,但第一个结果集的首航首列是NULL。
3、返回null,表示没有任何结果。

明白了这一点,很多时候代码可以简单些,比如说我们判断某条记录是否存在一般要这样写:

1SqlCommand command = new SqlCommand( "SELECT COUNT(ID) FROM Data WHERE ID = @ID", connection );
2//...
3if ( (int) command.ExecuteScaler() == 0 )


其实可以这样:

1SqlCommand command = new SqlCommand( "SELECT ID FROM Data WHERE ID = @ID", connection );
2//
3if ( command.ExecuteScaler() == null )
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
点击右上角即可分享
微信分享提示