C# 之 DataReader 和 DataSet 的区别
本文转载自:http://www.cnblogs.com/xinaixia/p/4920630.html ? 1. 获取数据的方式 代码如下:
while(datareader.read()) { .............. } dataview.datasource=datareader; dataview.databind(); [2]DataSet为离线操作数据,DataSet会将数据一次性读入内存,然后断开连接,这时其它操作就可以使用SqlConnection连接对象。 public string test = ""; protected void Page_Load(object sender,EventArgs e) { DataSet ds=new DataSet();//这里是你的数据,我就不写了 test = "<table>"; for (int i = 0; i < ds.Tables[0].Rows; i++) { test+="<tr><td>"+ds.Tables[0].Rows[i]["你要的字段"].ToString()+"</td></tr>" } test+="</table>"; }
<form id="form1" runat="server"> <%=test %> </form> 由于DataReader一次只读取一行数据,所以占用内存较小。但DataReader为只进且只读的,也就是只能单方向向前读取,如果你想回头去读取上一条数据是不允许的,并且不允许其修改数据。 2.获取数据的机制 3.其它区别 4.使用DataReader可以提高执行效率,有两种方式可以提高代码的性能:一种是基于序号的查找,一个是使用适当的Get方法来查找。 因为查询出来的结果一般都不会改变,除非再次改动查询语句,因此可以通过定位列的位置来查找记录。用这种方法有一个问题,就是可能知道一列的名称而不知道其所在的位置,这个问题的解决方案是通过调用DataReader 对象的GetOrdinal()方法,此方法接收一个列名并返回此列名所在的列号。例: 代码如下:
int id = reader.GetOrdinal("CategoryName"); while (reader.Read()) { Response.Write(reader.GetInt32(0).ToString() + " " + reader.GetString(1).ToString() + "<br />"); reader.Close(); } ? 注意: DataReader对象在调用其 Close() 方法关闭 DataReader 对象,然后调用 SqlConnection 对象的 Close 方法关闭与数据库的连接,如果在没有关闭之前又重新打开第二个连接,则会产生一条异常信息,如:并发问题。使用完SqlDataReader后,可以在程序中显示的调用 数据库连接对象的 Close() 方法关闭连接,也可以在调用Command对象的ExecuteReader方法时传递 CommandBehavior.CloseConnection 这个枚举变量,这样在调用SqlDataReader的 Close 方法时会自动关闭数据库连接。 ? //未式关闭连接 public SysFunction GetModelById(string id) { SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["sqlConStr"].ToString()); conn.Open(); SqlCommand cmd = new SqlCommand("SELECT * FROM SysFunction WHERE FunctionId =" + id,conn); SqlDataReader dataReader = cmd.ExecuteReader(); SysFunction model = new SysFunction(); while (dataReader.Read()) { model.FunctionName = dataReader["FunctionName"].ToString(); model.FunctionCode = dataReader["FunctionCode"].ToString(); } dataReader.Close(); dataReader.Dispose(); string drState = dataReader.IsClosed.ToString(); //True string connState = conn.State.ToString(); //Open return model; } //调用Connection 对象的 Close() 方法显式关闭连接 public SysFunction GetModelById(string id) { SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["sqlConStr"].ToString()); conn.Open(); SqlCommand cmd = new SqlCommand("SELECT * FROM SysFunction WHERE FunctionId =" + id,conn); SqlDataReader dataReader = cmd.ExecuteReader(); SysFunction model = new SysFunction(); while (dataReader.Read()) { model.FunctionName = dataReader["FunctionName"].ToString(); model.FunctionCode = dataReader["FunctionCode"].ToString(); } dataReader.Close(); dataReader.Dispose(); conn.Close(); //显式关闭连接 string drState = dataReader.IsClosed.ToString(); //True string connState = conn.State.ToString(); //Close return model; } //调用Command 对象的 ExecuteReader() 方法时传递 CommandBehavior.CloseConnection 参数 public SysFunction GetModelById(string id) { SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["sqlConStr"].ToString()); conn.Open(); SqlCommand cmd = new SqlCommand("SELECT * FROM SysFunction WHERE FunctionId =" + id,conn); //执行该cmd时,如果关闭关联的 DataReader 对象,则关联的 Connection 对象也将关闭 SqlDataReader dataReader = cmd.ExecuteReader(CommandBehavior.CloseConnection); SysFunction model = new SysFunction(); while (dataReader.Read()) { model.FunctionName = dataReader["FunctionName"].ToString(); model.FunctionCode = dataReader["FunctionCode"].ToString(); } dataReader.Close(); dataReader.Dispose(); string drState = dataReader.IsClosed.ToString(); //True string connState = conn.State.ToString(); //Close return model; } ? (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 在ASP.NET中,什么是’ASP’代码?
- asp.net-mvc – 通过MvcContrib进行协作编程的MEF与便携式区
- asp.net-core – 在强类型视图中呈现ViewComponent的Invali
- asp.net – 用于验证的数据注释,至少一个必填字段?
- asp.net-mvc – 为什么DropDownListFor不能识别编辑器模板中
- asp.net – w3wp.exe占用多少内存
- asp.net-mvc – ASP.NET MVC – 当参数为null时绑定空集合
- asp.net-mvc – 如何在ASP.NET MVC中向用户提供动作“成功”
- 在按钮执行回发之前触发的asp:按钮上添加jQuery click事件
- MVC学习一:EF