Asp.net中SqlDataAdapter和SqlCommand对比分析
2008-03-30 15:09
399 查看
一、SqlDataAdapter和DateSet
原理:DateSet是数据的内存驻留表示形式,它提供了独立于数据源的一致关系编程模型;从某种程度上说DateSet就是一个不可视的数据库。但真正与数据源打交道的是SqlDataAdapter,包括从数据源填充数据集和从数据集更新数据源。SqlDataAdapter使用Fill()方法将检索的数据填充到DateSet。
流程:IE——GridView——DataSet——SqlDataAdapter——SQL数据库
[align=left]public void BindGrid()[/align]
[align=left] {[/align]
[align=left] SqlDataAdapter myAdp = new SqlDataAdapter("select * from UserAdmin order by UserId desc", conn);[/align]
[align=left] DataSet ds = new DataSet();[/align]
[align=left] myAdp.Fill(ds, "Authors");[/align]
[align=left] //Label1.Text = ds.Tables[0].Rows.Count.ToString(); //得到共有多少条记录;[/align]
[align=left] GridView1.DataSource = ds.Tables["Authors"].DefaultView;[/align]
[align=left] GridView1.DataBind();[/align]
}
二、SqlCommand和SqlDataReader
原理:SqlCommand通过ExecuteReader()方法将得到的数据给SqlDataReader对象。
SqlDataReader逐行将从数据源获得的数据放进缓冲区进行处理。
优点:SqlDataReader执行速度快,提高应用程序性能。
优点原因:一旦数据可用,SqlDataReader就会立即检索该数据,而不是等待返回查询的全部结果;默认情况下,一次只在缓冲区存储一行,从而降低系统开销。
缺点:使用不灵活。
流程:IE——SqlDataReader——SqlCommand——SQL数据库
注:每次使用完SqlDataReader对象后一定要调用Close()方法将其关闭。因为SqlDataReader对象以独占的方式使用Connection。
例:
[align=left] SqlCommand myconn = new SqlCommand("select * from v_economy2_comidd where eid=" + Request.QueryString["eid"] + "", conn);[/align]
[align=left] conn.Open();[/align]
[align=left] SqlDataReader rd = myconn.ExecuteReader();[/align]
[align=left] rd.Read();[/align]
[align=left] Lbyear1.Text = rd["year1"].ToString();[/align]
[align=left] Lbmonth1.Text = rd["month1"].ToString();[/align]
Lbcom_name.Text = rd["com_name"].ToString();
[align=left] rd.Close();[/align]
conn.Close();
原理:DateSet是数据的内存驻留表示形式,它提供了独立于数据源的一致关系编程模型;从某种程度上说DateSet就是一个不可视的数据库。但真正与数据源打交道的是SqlDataAdapter,包括从数据源填充数据集和从数据集更新数据源。SqlDataAdapter使用Fill()方法将检索的数据填充到DateSet。
流程:IE——GridView——DataSet——SqlDataAdapter——SQL数据库
[align=left]public void BindGrid()[/align]
[align=left] {[/align]
[align=left] SqlDataAdapter myAdp = new SqlDataAdapter("select * from UserAdmin order by UserId desc", conn);[/align]
[align=left] DataSet ds = new DataSet();[/align]
[align=left] myAdp.Fill(ds, "Authors");[/align]
[align=left] //Label1.Text = ds.Tables[0].Rows.Count.ToString(); //得到共有多少条记录;[/align]
[align=left] GridView1.DataSource = ds.Tables["Authors"].DefaultView;[/align]
[align=left] GridView1.DataBind();[/align]
}
二、SqlCommand和SqlDataReader
原理:SqlCommand通过ExecuteReader()方法将得到的数据给SqlDataReader对象。
SqlDataReader逐行将从数据源获得的数据放进缓冲区进行处理。
优点:SqlDataReader执行速度快,提高应用程序性能。
优点原因:一旦数据可用,SqlDataReader就会立即检索该数据,而不是等待返回查询的全部结果;默认情况下,一次只在缓冲区存储一行,从而降低系统开销。
缺点:使用不灵活。
流程:IE——SqlDataReader——SqlCommand——SQL数据库
注:每次使用完SqlDataReader对象后一定要调用Close()方法将其关闭。因为SqlDataReader对象以独占的方式使用Connection。
例:
[align=left] SqlCommand myconn = new SqlCommand("select * from v_economy2_comidd where eid=" + Request.QueryString["eid"] + "", conn);[/align]
[align=left] conn.Open();[/align]
[align=left] SqlDataReader rd = myconn.ExecuteReader();[/align]
[align=left] rd.Read();[/align]
[align=left] Lbyear1.Text = rd["year1"].ToString();[/align]
[align=left] Lbmonth1.Text = rd["month1"].ToString();[/align]
Lbcom_name.Text = rd["com_name"].ToString();
[align=left] rd.Close();[/align]
conn.Close();
相关文章推荐
- asp.net SqlDataAdapter对象使用札记
- Asp.net中SqlDataAdapter和SqlCommand对比分析
- Asp.net中SqlDataAdapter和SqlCommand对比分析(二)
- Asp.net中SqlDataAdapter和SqlCommand对比分析
- ADO.NET—Asp.net 用DataSet对象更新数据(SqlDataAdapter)
- asp.net里SqlDataAdapter存在Sql注入漏洞
- asp.net SqlDataAdapter Update
- ADO.NET—Asp.net 用DataSet对象更新数据(SqlDataAdapter)
- Asp.net 用DataSet对象更新数据(SqlDataAdapter) DataTable加主键
- 在asp.net中使用sql server存储过程 (包括SqlDataAdapter调用存储过程)
- Asp.net 用DataSet对象更新数据(SqlDataAdapter)
- 在asp.net中使用sql server存储过程 (包括SqlDataAdapter调用存储过程)
- ASP.net中SqlDataAdapter和SqlCommand对比分析
- asp.net SqlDataAdapter对象使用札记
- Asp.net SqlDataReader转成Datatable
- 让 ADO.NET 2.0 的 SqlCommand 和 SqlDataAdapter 合作
- ADO.NET - 1.基础(SqlCommand\ExecuteScalar\ExecuteReader\sqlDataAdapter)
- C# ADO.NET SqlDataAdapter中传递参数
- ADO.NET ASP.NET 将 SQLDatareader 转换成 List
- ADO.NET学习之SqlDataAdapter,DataSet