DataReader包括:sqlDataReader,oracleDataReader,oledbDataReader,odbcDataReader;
DataAdapter包括:sqlDataAdapter,oracleDataAdapter,oledbDataAdapter,odbcDataAdapter。
对于各数据类型,DataReader和DataAdapter,功能都是一样的。以下依Aceess的oledb为例。
DataReader是一个向前的指针,本身并不包含数据,调用一次Read()方法它就向前到下一条记录,一个DataReader必须单独占用一个打开的数据库连接!【在使用 OleDbDataReader 时,关联的 OleDbConnection 正忙于为 OleDbDataReader 服务,对 OleDbConnection 无法执行任何其他操作,只能将其关闭。除非调用 OleDbDataReader 的 Close 方法,否则会一直处于此状态。例如,在调用 Close 之前,无法检索。】【只能通过再申请一个新的连接变量OleDbConnection】
cmd2.CommandText = sql;
OleDbDataReader odr = cmd2.ExecuteReader();
while (odr.Read()){...}
-------------------------------
DataAdapter象一座桥梁,一头连起数据库表,一头连起一个DataSet或者DataTable,在把数据库中的数据填充到DataSet或DataTable后就可以“过河拆桥”,不用再连接到数据库,而可以直接从DataSet或DataTable中获取数据。
DataSet myds = new DataSet();
cmd.CommandText = sql;
OleDbDataAdapter myda = new OleDbDataAdapter(cmd);
myda.Fill(myds, "temp");
for (int i = 0; i < myds.Tables["temp"].Rows.Count; i++)
{
sta = myds.Tables["temp"].Rows[i][0].ToString().Trim();
...}
System.Data.OleDb.OleDbDataAdapter,可以通过它直接与DataSet建立联系,并操作数据源,功能相对强大,但比较消耗系统资源;System.Data.OleDb.OleDbDataReader呢,有点儿像ADO中的那个只读向前的记录集,它常用在只需要依次读取并显示数据的场合。OleDbDataReader能实现的功能,OleDbDataAdapter都能实现,但有些功能,却只有OleDbDataAdapter才能实现。不过,它耗用的系统资源比System.Data.OleDb.OleDbDataAdapter少。
另外,从数据量级来说,OleDbDataAdapter的Fill过程较慢(写内存),一般用于小型数据处理;OleDbDataReader,一般用于大型数据处理。【经过测试,如果有大量的数据操作,最好是自己写OleDbCommand,会比OleDbDataAdapter操作数据库快很多。http://huliqin1022.blog.163.com/blog/static/131711530200910135577476/】