• 【参考】修改DataSet里的内容


    【参考】修改DataSet里的内容

    首先我们需要打开一个联结:
    string MyConnString = "Driver={Microsoft Access Driver (*.mdb)}; DBQ=c:/test/test.mdb;";
    string strComm = "select * from UserList";
    ADOConnection MyConnection = new ADOConnection(MyConnString);
    ADODataSetCommand MyComm = new ADODataSetCommand(strComm,MyConnection);


    这里我们为了讲解方便,只在dataset存入一个表的内容:
    DataSet MyDataSet = new DataSet();
    MyComm.FillDataSet(MyDataSet,"UserList");

    此时我们就获得了一个拥有UserList表数据的DataSet。在讲解DataSet之前,我们还需要了解DataSet的结构下面是DataSet的结构树
    DataSet
    RelationsCollection
    ExtendedProperties
    TablesCollection  
    DataTables

    Rows
    Columns
    其它
    由于我们研究的是DataTable,其它的我们暂时不管他们。一个DataSet中包含多个DataTable,一个DataTable又包含有多个Row,这就是我们操作DataSet的基础啦:)


    添加数据


    添加一数据,从上面的列表中我们可以看出,其实就是添加一行row,这里我们也来演示一下如何添加一行数据,我们程序一切以dataset为顶点, 呵呵,如果tablescollection,rowscollection下去的话,还有一些烦人的dt.acceptchanges这些方法的调用, 很烦人,还是一次搞定吧。


    datarow dr=MyDataSet.Tables["UserList"].NewRow();
    dr["UserName"] = "周讯";
    dr["ReMark"] = "100";
    dr["Comment"] = "漂亮MM";
    MyDataSet.Tables.Rows.Add(dr);


    第一行,我们建立一个新的数据行,它用来储存我们新加入的数据。然后我们在这个数据行中加入我们需要的数据。dr["username"]表明是对 username字段进行添加,你可以使用dr[1]来添加信息,但是这需要我们事先知道字段在数据表的位置,而且在不知道数据表结构的情况很难知道我们 添加的数据的对应情况,所以还是用字段名为好。
           最后我们使用RowsCollection的Add方法,将我们新建这一行加入到数据表中。
    修改数据
    知道如何添加数据后,修改数据也是很简单的事情了.
    MyDataSet.Tables["UserList"].Rows[0]["UserName"]="飞刀大哥";
    这样我们就修改了第一行数据中的UserName字段。


    删除数据


    删除数据,主要是使用rowscollection提供的delete方法,看下面的程序也是很简单的事情啦:)
    MyDataSet.Tables["UserList"],Rows[0].Delete();
    这一行数据就已经被删除了。
    恢复数据
    有时候我们添加/修改数据会出现错误,这时候,就需要恢复原来的数据。下面的程序,显示如何判断是否有错误发生:
    if(MyDataSet.HasErrors)
    {
    MyDataSet.RejectChanges();
    }

    首 先我们检查DataSet中是否有错误发生,如果有就使用RejectChanges()方法,恢复DataSet中的数据。注意这里恢复是在 DataSet中所有表以及表中DataRow中的数据,也就是在此交次操作的数据全部恢复。如果我们只需要恢复部分内容,我们可以使用 DataTable或DataRow的RejectChanges(),这里就不详细讲解了,使用方法和DataSet一样,只是操作的对像不同而已。


    探测dataset是否有改动


    我们在将dataset送交给数据库去保存去,我们需要看看这个dataset是否已经被改动了。如果没有改动,我们也就没有必要去修改数据库了。


    if(mydataset.haschanges)
    {
        //保存
    }else{
        //不进行任何操作
    }


    更新数据库


    我们上面的操作,都只是针对dataset的,没有操作数据库,但是我们的目的还是要将数据保存到数据中去,所以我们这里就需要调用 datasetcommand的update方法。下面的程序显示如何将dataset的数据交给数据库。mycomm.update (mydataset);
    很简单的一句,呵呵。这里要注意,如果一个DataSet中包含有多个表,而我们只更新一个,那我们就必须写明更新的数据表名:
    MyComm.Update(MyDataSet,"UserList");
    当Update方法被调用后,DataSetCommand会将数据库中的数据与DataSet中的数据相比较,对不相同的地方进行更新。

  • 相关阅读:
    水晶报表设计--基本概念
    微信公众平台开发小结
    CCF计算机职业认证考试
    Linux 命令
    百度搜索引擎的一些技巧
    Windows的一些操作命令
    Eclipse:写jsp 出现的一些问题
    操作系统(基本问题)
    C语言编程技巧(注意点)
    mysql命令报错问题
  • 原文地址:https://www.cnblogs.com/guyuehuanhuan/p/1948129.html
Copyright © 2020-2023  润新知