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

        /// <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;
        }

  

转载于:https://www.cnblogs.com/sunqiang/p/6109268.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值