• DataReader与DataAdapter的区别


    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/

  • 相关阅读:
    第八次课程作业
    第七次课程作业
    第六次课程作业
    第五次课程作业
    第三次课程作业
    第二次课程作业
    第一次课程作业
    FZU.Software Engineering1816 · First Homework -Preparation
    个人简介
    福大软工1816 · 第二次作业
  • 原文地址:https://www.cnblogs.com/yuan2013/p/yuan.html
Copyright © 2020-2023  润新知