现在的位置: 首页 > 综合 > 正文

ADO.NET 2.0中的SqlCommand.ExecutePageReader [转贴]

2013年11月21日 ⁄ 综合 ⁄ 共 1846字 ⁄ 字号 评论关闭
在.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很可惜。:'(

【上篇】
【下篇】

抱歉!评论已关闭.