2

在我试图理解的软件中,DataReader 类是通过 ExecuteReader() 从 IDbCommand 类型(继承)接收的。

我对 C# 和数据库通信还很陌生,所以:DataReader 如何处理与数据库的通信?

  • 它在执行 ExecuteReader() 时是否从查询中接收到整个响应,然后在本地使用 reader.Read() 逐步执行响应?
  • 或者每个 reader.Read() 调用是否通过网络从数据库中获取下一项?
  • 或者,我没有想到的其他东西?
4

1 回答 1

3

从技术上讲,“它取决于”,因为它DbDataReader是一个抽象类,可以以任何你认为合适的方式实现——包括缓冲整个结果。

但实际上,该接口是面向零碎阅读的,实现也是如此。如果我们以SqlDataReader示例为例,初始调用.ExecuteReader()将开始处理命令并导致服务器提供结果,然后每次调用.Read()都会通过网络获取一行。但是,并非每次调用都.Read()必然涉及网络流量,因为多个行可能捆绑在一个数据包中,因此可以从缓冲区满足读取。

这同样适用于列,甚至——它们可能跨越网络数据包甚至包含流,因此所有.GetX()方法都可能涉及额外的网络往返(这就是为什么它们都具有Async.NET 4.5 及更高版本的原因)。

于 2016-03-16T10:44:33.557 回答