加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

.net – 应该使用哪个IsDBNull和IsNull?

发布时间:2020-12-17 00:06:36 所属栏目:大数据 来源:网络整理
导读:如果在VB.NET中我有DataRow,我想测试列值是否为空,我应该使用: myDataRow.IsNull("Column1") 要么 IsDBNull(myDataRow("Column1")) 简短的答案:使用第一种方式,它更快,因为第一种方法使用预先计算的结果,而第二种方法需要在每次调用它时即时重新计算它. 很
如果在VB.NET中我有DataRow,我想测试列值是否为空,我应该使用:
myDataRow.IsNull("Column1")

要么

IsDBNull(myDataRow("Column1"))
简短的答案:使用第一种方式,它更快,因为第一种方法使用预先计算的结果,而第二种方法需要在每次调用它时即时重新计算它.

很长的答案:(你需要读取C#代码来理解这个部分; MS在C#中提供框架代码,但是VB程序员应该能够得到一般的想法)

这是在DataRow的IsNull调用中发生的情况:

public bool IsNull(string columnName) {
    DataColumn column = GetDataColumn(columnName);
    int record = GetDefaultRecord();
    return column.IsNull(record);
}

column.IsNull执行快速断言,并将调用转发到DataStorage,一个内部类:

internal bool IsNull(int record) {
    Debug.Assert(null != _storage,"no storage");
    return _storage.IsNull(record);
}

最后,这里是_storage.IsNull所做的:

public virtual bool IsNull(int recordNo) {
    return this.dbNullBits.Get(recordNo);
}

由于dbNullBits是BitArray,因此此操作非常快速地完成.

现在考虑索引器myDataRow(“Column1”)的作用(在将结果传递给IsDBNull之前将其称为索引器):

get {
    DataColumn column = GetDataColumn(columnName);
    int record = GetDefaultRecord();
    _table.recordManager.VerifyRecord(record,this);
    VerifyValueFromStorage(column,DataRowVersion.Default,column[record]);
    return column[record];
}

请注意,IsNull方法和索引器的前两行是相同的.但是,以下三行需要执行验证,并且获取该值本身.只有在此之后,您的代码才能开始计算其目标值 – 这个标志告诉它值是否为DBNull.这需要更多的计算,但更重要的是,它每次执行检查时都需要一些计算.这比使用预先计算的值慢.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读