gpt4 book ai didi

c# - 检查是否已在 SqlDataReader 上调用 read()

转载 作者:行者123 更新时间:2023-11-30 15:40:19 24 4
gpt4 key购买 nike

我正在编写一些辅助函数,这些函数采用 SqlDataReader 并处理结果。现在通常你会像这样构造循环:

while(reader.read()){
// Read fields
}

但我将向函数传递一个已经定位在一行中的读取器,在这种情况下,我希望它处理当前行。如果在调用函数之前未调用 read(),则上面的代码只会输出整个结果集。

我希望函数做这样的事情:

if(!reader._dataReady)
rowExists = reader.read() // Read
while(rowExists){
// read fields
rowExists = reader.read()
}

_dataReady 是 SqlDataReader 的实际成员,似乎可以满足我的需要,但它是私有(private)的!当然有一种方法可以确定读取器是否位于实际行上,而不是尝试读取字段并捕获异常。

最佳答案

为什么不直接继承 SqlDataReader 并创建 Read() 方法?我现在在我的所有项目中都有它:

public class SafeDataReader : IDataReader, SqlDataReader
{
public IDataReader reader {get;set;}
public int GetInt32(string aFieldName, int aDefault);
public int? GetInt32Nullable(string aFieldName);
....
}

关于c# - 检查是否已在 SqlDataReader 上调用 read(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9387101/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com