ADO.NET 2.0中的SqlCommand.ExecutePageReader

http://blog.joycode.com/liuhuimiao/

在.NET 2.0 PDC或Beta1中,可以看到SqlCommand对象新增了个ExecutePageReader方法,该方法实现了分页读取数据的功能。对于分页读取数据,在ADO.NET1.1中(当然2.0也适合)一般常用动态构造SQL语句实现:

SqlDataReader GetPage(int pageNumber, int pageSize)
{
//pageNumber: 从 0 开始计数的页码
//pageSize: 每页的记录数
String command = String.Format("SELECT * FROM (SELECT TOP {0} * FROM " +
"Products ORDER BY ProductID) AS t1 WHERE ProductID NOT IN " +
"(SELECT TOP {1} ProductID FROM Products ORDER BY ProductID) ",
pageSize
* (pageNumber + 1), pageSize * pageNumber);

SqlConnection conn
= new SqlConnection("server=.;database=Northwind;Trusted_Connection=yes");
SqlCommand cmd
= new SqlCommand(command, conn);
conn.Open();
SqlDataReader dr
= cmd.ExecuteReader(CommandBehavior.CloseConnection);
return dr;
}

有时为更好实现分页性能效果,也可以采用存储过程建立临时表的方式进行数据分页,但原理基本都差不多。在ADO.NET 2.0 PDC/Beta1中,用SqlCommand.ExecutePageReader进行数据分页:

SqlDataReader GetPageReader(int pageNumber, int pageSize)
{
int startIndex = (pageNumber - 1) * pageSize;
String command
= "SELECT * FROM Products";
SqlConnection conn
= new SqlConnection("server=.;database=Northwind;Trusted_Connection=yes");
SqlCommand cmd
= new SqlCommand(command, conn);
conn.Open();
SqlDataReader dr
= cmd.ExecutePageReader(CommandBehavior.CloseConnection, startIndex, pageSize);

return dr;
}

最后绑定第2页的5行数据(ProductID从6到10)到GridView1上:

GridView1.DataSource = GetPage(1, 5);
GridView1.DataBind();

从上可以看到,用了ExecutePageReader确实简单了很多。但是,很“不幸”告诉大家,ExecutePageReader在未来版本中将不会出现,也就是说被cut掉了。至于cut的真正原因,还真不知道。不过,我试图用Reflector去看其内部,发现这样一个调用顺序:ExecutePageReader()—》SqlResultSet.CompleteOpenForPageReader()—》SqlResultSet.FetchInternal()—》执行存储过程sp_cursorfetch,也就是实际ExecutePageReader使用了SQLServer的服务器游标进行数据分页读取,但这跟它被cut是否有关?这么好用的一个功能被cut是不是有其他考虑?或许ADO.NET开发小组在鱼和熊掌取舍之间已经做了抉择,只是我还是觉得ExecutePageReader(据说SqlResultSet也被cut,然后连同ExecutePageReader被cut)被cut很可惜。

你可能感兴趣的:(sql,.net,SQL Server,Blog)