转载地址:
http://dev.rdxx.com/NET/ADONET/2009/2/2420375960327_2.shtml
(接上)拥有数据表(DataTable)数据表关联(DataRelation)。DataSet中可以存储多张表等。DataSet拥有类似于数据库的结构,但它并不等同于数据库。首先他可以存储来自数据库的数据,而且还可以存储其他格式的数据,比如 XML格式文档;
1.查询数据
讲到DataSet的数据库应用,先要了解ADO.NET中的另一个对象DataAdapter .
它也分为SqlDataAdapter 和OleDbDataAdapter
建DataAdapte:
OleDbDataAdapter MyAdapter=new OleDbDataAdapter();
SqlDataAdapter MyAdapter=new SqlDataAdapter();
取得的DataAdapter 对象时必须赋予一个连接对象:
MyAdapter.SelectCommand.Connection = MyConn; 或
MyAdapter.UpdateCommand.Connection =Myconn; 或
MyAdapter.DeleteCommand.Connection = MyConn; 或
MyAdapter.InsertCommand.Connection =Myconn;
如果需要执行SQL语句,那么还必须给相应的CommandText 属性赋值。代码为:
MyAdapter.*Command.CommandText = SQL语句;
写这么多行代码似乎有些麻烦,如果你只是查询数据库,则可以在建立 DataAdapter实例时就完成上述工作。
OleDbDataAdapter MyAdapter = new OleDbDataAdapter(strSelect,objConnection); <%@ Page Language="C#" Runat="Server"%> <%@ Import Namespace="System.Data"%> <%@ Import Namespace="System.Data.OleDb"%> <script Language="C#" Runat="Server"> public void Page_Load(Object src,EventArgs e) { string MyConnString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+Server.MapPath(".")+"\\DataBase\\db3.mdb;"; string strSel="select * from Score"; //建立一个DataSet 实例 DataSet ds=new DataSet(); OleDbConnection MyConn= new OleDbConnection(MyConnString); OleDbDataAdapter MyAdapter = new OleDbDataAdapter(strSel,MyConn); MyAdapter.Fill(ds,"Score"); dg1.DataSource=ds.Tables["Score"].DefaultView; dg1.DataBind(); } </script> <asp:DataGrid id="dg1" runat="Server" Headerstyle-BackColor="#aaaadd" AlternatingItemstyle-BackColor="#eeeeee" />
将DataAdapter 于 DataSet 相联系的是 DataAdapter 对象的 Fill 方法。他有很多中用法: MyDataAdapter.Fill(DataSet) MyDataAdapter.Fill(DataSet,TableName)
MyDataAdapter.Fill(DataSet, StartRow , RowsCount, TableName)
DataSet 绑定至 DataGrid 控件显示:
1.dg1.DataSource= ds.Tables[“Score”].DefaultView;
dg1.DataBind();
2.dg1.DataSource=ds;
dg1.DataMember=”Score”;
dg1.DataBind();
提示: DataSet中的各种集合,访问子项有两种方法,一种是用子项的名,一种是用数字索引.比如要访问表”Score”,可以用: DataSet.Tables[0] 访问 (多张表依次类推)
2. 插入数据:
DataSet 的结构和数据库相似,所有插入数据实质上就是在DataSet 的数据表里插入一行(DataRow)
//新建一行
DataRow dr= ds.Tables[“Score”].NewRow();
dr. [“Name”] = “addme”;
dr. [“class”] =”201”;
ds.Tables[“Score”].Rows.Add(dr); //将新建的行加到DataTable 的DataRow集合中
这样对DataSet的操作仅仅是在DataSet中执行,并不影响数据库中的数据,要使用DataAdapter 的 Update 方法(有多种方法).
1. DataAdapter.Update(DataSet) ;
2. DataAdapter.Update(DataSet, TableName);
3.更新数据:
实际就是在DataSet 数据行上面直接修改数据
DataRow dr = ds .Tables[“Score”].Rows[0]; //取出第一行
dr. [“Name”] = “比尔”; //修改
dr. [“class”] =”201”;
如果要更新数据库,则再调用 Update 方法
4.删除数据:
找到相应的数据行,然后删除
DataRow dr =ds.Tables[“Score”].Row[0];
dr.Delete();
注意: DataAdapter 对象在数据发生改变时,并不能自动产生数据库系统所需的交易sql语句,
所有要建立一个CommandBuilder 对象 它能自动产生交易的sql语句.
OleDbCommandBuilder custcb = new OleDbCommandBuilder(MyAdapter);
5.DataSet 的其他特征
DataSet 、DataTable 和DataRow 都有一个十分有用的方法----RejectChanges,
它指操作对象拒绝已经发生的改变,将数据复原.该方法于AcceptChanges , HasErrors等属性连用非常有用.
If (DataSet.HasErrors) { DataSet.RejectChanges(); } else { DataSet.AcceptChanges();}