/* 作者: 季健国
* 创建时间: 2012/7/23 9:39:04
*
*/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Ant.Service.Common
{
///
/// 这是一个用c#写的分页构造过程(为了免去数据库写存储过程的麻烦)
///
public class PaginationHelper
{
#region - 属性 -
///
/// 表名
///
public string TableName { get; set; }
///
/// 连接语句
///
public string InnerJoin { get; set; }
///
/// 查询字段
///
public string SelectFields { get; set; }
///
/// 排序字段名
///
public string OrderName { get; set; }
///
/// 每页记录数
///
public int PageSize { get; set; }
///
/// 页号
///
public int PageNumber { get; set; }
///
/// 排序类别
///
public string OrderType { get; set; }
///
/// 查询条件
///
public string WhereCondition { get; set; }
#endregion
#region - 构造函数 -
///
/// 构造函数(需要对where参数进行安全性过滤,最好配合可变参数执行)
///
/// 表名
/// 排序字段名称
/// 每页记录数
/// 页号
/// 排序方式
/// 查询条件
public PaginationHelper(string tableName, string orderName, int pageSize, int pageNumer, string orderType, string where)
: this(tableName, "", "*", orderName, pageSize, pageNumer, orderType, where)
{
}
///
/// 构造函数(需要对where参数进行安全性过滤,最好配合可变参数执行)
///
/// 表名
/// 连接语句
/// 查询字段,默认为*
/// 排序字段名称
/// 每页记录数
/// 页号
/// 排序方式
/// 查询条件
public PaginationHelper(string tableName, string innerJoin, string selectFields, string orderName, int pageSize, int pageNumber, string orderType, string where)
{
this.TableName = tableName;
this.InnerJoin = innerJoin;
this.SelectFields = selectFields; ;
this.OrderName = orderName;
this.PageSize = pageSize;
this.PageNumber = pageNumber<=0?1:pageNumber;//如果PageNumber<0则赋值为1
this.OrderType = orderType.ToLower() == "desc" ? "desc" : "asc";
this.WhereCondition = where;
}
#endregion
#region - 方法 -
///
/// 获得记录总数的sql语句
///
///
public string GetCount()
{
string CommandText = "select count(*) as Total from [ " + TableName + " ] " + InnerJoin;
if (!WhereCondition.IsNullOrEmpty())
{
CommandText += " where " + WhereCondition;
}
return CommandText;
}
#endregion
#region 获取Select Top配合 Max,Min方式的查询分页sql语句(千万级别分页)
///
/// 获取Select Top配合 Max,Min方式的查询分页sql语句(千万级别分页)
///
///
public string GetSelectTopByMaxOrMinPagination()
{
//主语句
StringBuilder sbSql = new StringBuilder(300);
//临时变量
string strTemp = "";
//排序类型
string strOrder = "";
if (OrderType == "desc")
{
strTemp = " <( select min ";
}
else
strTemp = " > ( select max ";
//排序类型生成
strOrder = " order by [" + OrderName + "] " + OrderType + " ";
//如果页码为1就做优化查询用Select Top的方式
if (PageNumber == 1)
{
//查询条件判断
if (!WhereCondition.IsNullOrEmpty())
sbSql.AppendFormat("select top {0} {1} from [{2}] {3} where {4} {5}", PageSize, SelectFields, TableName, InnerJoin, WhereCondition, strOrder);
else
sbSql.AppendFormat("select top {0} {1} from [{2}] {3} {4}", PageSize, SelectFields, TableName, InnerJoin, strOrder);
}
else
{
if (!WhereCondition.IsNullOrEmpty())
{
sbSql.AppendFormat("select top {0} {1} from {2} {3} where [{4}] {5} ([{4}]) from ( select top {6} [{4}] from [{2}] {3} {7} ) as tblTmp) and {8} {7} ", PageSize, SelectFields, TableName, InnerJoin, OrderName, strTemp, (PageNumber - 1) * PageSize, strOrder, WhereCondition);
}
else
sbSql.AppendFormat("select top {0} {1} from {2} {3} where [{4}] {5} ([{4}]) from (select top {6} [{4}] from [{2}] {3} {7} ) as tblTmp) {7}", PageSize, SelectFields, TableName, InnerJoin, OrderName, strTemp, (PageNumber - 1) * PageSize, strOrder);
}
return sbSql.ToString();
}
#endregion
#region 通过RowNumber的方式分页(百万级别左右)
///
/// 通过RowNumber的方式分页(百万级别左右)
///
///
public string GetRowNumberPagination(int totalCount)
{
//开始记录和结束记录,总页数,总记录数
int startRecord = 0, endRecord = 0, totalPage = 0;
//计算开始页码
startRecord = (PageNumber - 1) * PageSize + 1;
//计算结束页码
endRecord = startRecord + PageSize - 1;
//获取总记录数的sql和查询的sql
string totalCountSql, sqlString;
totalCountSql = "select @TotalRecord = count(*) from " + TableName + " ";//总记录数sql语句
sqlString = string.Format("(select row_number() over (order by {0} {1}) as rowId,{2} from {3} ", OrderName, OrderType, SelectFields, TableName);
//添加查询条件
if (!WhereCondition.IsNullOrEmpty())
{
totalCountSql += " where " + WhereCondition;
sqlString += " where " + WhereCondition;
}
//计算总页数
totalPage = (int)Math.Ceiling(totalCount * 1.0 / (double)PageSize);
sqlString = string.Format(" select * from {0}) as t where rowId between {1} and {2} ", sqlString, startRecord, endRecord);
return sqlString;
}
#endregion
}
}