码迷,mamicode.com
首页 > Windows程序 > 详细

C# ado.net 使用 row_number over() 简单的分页示例

时间:2016-11-28 15:24:37      阅读:225      评论:0      收藏:0      [点我收藏+]

标签:sha   order   日志   cut   计算   ges   for   err   ndt   

        /// <summary>
        /// 获取Paging列表
        /// </summary>
        public List<HousesAgentEntity> GetPageList(int pageIndex, int pageSize, out int amount, string where)
        {
            int count = 0; //总页数

            string sqlCount = "Select Count(*) From HousesAgent" + where;//根据条件计算总页数

            List<HousesAgentEntity> list = new List<HousesAgentEntity>();

            #region 组装分页的sql语句 
                       
            string sql = string.Format(@"Select * From ( Select Row_Number() Over(Order By UserId desc) Rows, * From HousesAgent {0} ) tb Where Rows > @Begin And Rows <= @End", where);  

            SqlParameter[] parameters = {
            new SqlParameter("@Begin", (pageIndex-1) * pageSize),
            new SqlParameter("@End", pageIndex * pageSize)
            };

            #endregion


            try
            {

                SqlDataReader dr = SqlSimpleHelper.ExecuteReader(SqlSimpleHelper.ConnectionString, CommandType.Text, sql, parameters);
                list = DataReaderToList(dr);

                Object obj = SqlSimpleHelper.ExecuteScalar(SqlSimpleHelper.ConnectionString, CommandType.Text, sqlCount);
                if (obj != null)
                {
                    int.TryParse(obj.ToString(), out count);
                }
                amount = count;
            }

            catch (Exception ex)
            {
                //记录异常日志
                LogHelper.WriteErrorLog(GetErrorMethod("GetPageList"), ex.Message);
                amount = 0;
            }
            return list;
        }

  

C# ado.net 使用 row_number over() 简单的分页示例

标签:sha   order   日志   cut   计算   ges   for   err   ndt   

原文地址:http://www.cnblogs.com/sunqiang/p/6109268.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!