从复杂性来看,DataSet需要的系统开销显然要比DataReader多,在性能和内存的使用上就 会有负面影响.
因此都应该优先考虑使用DataReader对象而不是DataSet,仅在下列情况下使用DataSet对象.
1.当需要远程控制数据,即与数据存储断开连接,并需要将数据传递到应用程序的另一层或客户端应用程序,存储这些数据以便在过程中或类似的场景中使用\编辑他们
2.当需要存储\传输或访问多个表时,以及这些表之间的关系时.
3.当需要使用DataSet和DataAdapter的内置方法来更新源数据库中的数据,而不是执行单个SQL语句或存储过程
4.当需要利用XML文档和相应的"关系"行集的同步功能时
5.在某些数据绑定场合中,如将同一数据绑定到多个控件上,或在DATAGRID控件中使用自动的记录分页调度技术时,不能将DataReader当成数据源.
6.当需要迭代数据行,并要求能在行集中自由的前后移动时,就不能使用DataReader.