/****** 对象: StoredProcedure [dbo].[PageList] 脚本日期: 09/05/2008 23:57:19 ******/
SET ANSI_NULLS OFF
GO
SET QUOTED_IDENTIFIER OFF
GO
ALTER PROCEDURE [dbo].[PageList]
@tblName varchar(255), -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='', -- 排序的字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@doCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where)
AS
declare @strSQL varchar(5000) -- 主语句
declare @strTmp varchar(110) -- 临时变量
declare @strOrder varchar(400) -- 排序类型
if @doCount != 0
begin
if @strWhere !=''
set @strSQL = "select count(*) as Total from [" + @tblName + "] where "+@strWhere
else
set @strSQL = "select count(*) as Total from [" + @tblName + "]"
end
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况
else
begin
if @OrderType != 0
begin
set @strTmp = "<(select min"
set @strOrder = " order by [" + @fldName +"] desc"
--如果@OrderType不是0,就执行降序,这句很重要!
end
else
begin
set @strTmp = ">(select max"
set @strOrder = " order by [" + @fldName +"] asc"
end
if @PageIndex = 1
begin
if @strWhere != ''
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from [" + @tblName + "] where " + @strWhere + " " + @strOrder
else
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["+ @tblName + "] "+ @strOrder
--如果是第一页就执行以上代码,这样会加快执行速度
end
else
begin
--以下代码赋予了@strSQL以真正执行的SQL代码
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["+ @fldName + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"+ @strOrder
if @strWhere != ''
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
+ @fldName + "] from [" + @tblName + "] where " + @strWhere + " "
+ @strOrder + ") as tblTmp) and " + @strWhere + " " + @strOrder
end
end
exec (@strSQL)
/// <summary>
/// 利用通用存储过程实现快速分页
/// </summary>
/// <param name="tblName">表名</param>
/// <param name="strGetFields">字段名,用逗号分隔</param>
/// <param name="fldName">排序字段</param>
/// <param name="PageSize">每页显示记录数</param>
/// <param name="PageIndex">当前页</param>
/// <param name="doCount">返回记录总数, 非 0 值则返回</param>
/// <param name="OrderType">设置排序类型, 非 0 值则降序</param>
/// <param name="strWhere">查询条件 (注意: 不要加 where)</param>
/// <returns>返回DataTable</returns>
public DataTable Page_List(string tblName, string strGetFields, string fldName, int PageSize, int PageIndex, int doCount, int OrderType, string strWhere)
{
//tblName表名
//strGetFields 字段名,用逗号分隔
//fldName排序字段
//PageSize每页显示记录数
//PageIndex当前页
//doCount返回记录总数, 非 0 值则返回
//OrderType设置排序类型, 非 0 值则降序
//strWhere查询条件 (注意: 不要加 where)
//SqlDataAdapter rs = new SqlDataAdapter("PageList", conn);
//int AllCount = 0;
//AllCount = GetTableCount(tblName, strWhere);
SqlCommand myCommand = new SqlCommand("PageList", conn);
myCommand.CommandType = CommandType.StoredProcedure;//命令类型
myCommand.Parameters.Add(new SqlParameter("@tblName", SqlDbType.VarChar, 100));
myCommand.Parameters["@tblName"].Value = tblName;
myCommand.Parameters.Add(new SqlParameter("@strGetFields", SqlDbType.VarChar, 1000));
myCommand.Parameters["@strGetFields"].Value = strGetFields;
myCommand.Parameters.Add(new SqlParameter("@fldName", SqlDbType.VarChar, 50));
myCommand.Parameters["@fldName"].Value = fldName;
myCommand.Parameters.Add(new SqlParameter("@PageSize", SqlDbType.Int, 4));
myCommand.Parameters["@PageSize"].Value = PageSize;
myCommand.Parameters.Add(new SqlParameter("@PageIndex", SqlDbType.Int, 4));
myCommand.Parameters["@PageIndex"].Value = PageIndex;
myCommand.Parameters.Add(new SqlParameter("@doCount", SqlDbType.Int, 4));
myCommand.Parameters["@doCount"].Value = doCount;
myCommand.Parameters.Add(new SqlParameter("@OrderType", SqlDbType.Int, 4));
myCommand.Parameters["@OrderType"].Value = OrderType;
myCommand.Parameters.Add(new SqlParameter("@strWhere", SqlDbType.VarChar, 1000));
myCommand.Parameters["@strWhere"].Value = strWhere;
DataTable dt = new DataTable("showClass");
SqlDataAdapter rs = new SqlDataAdapter(myCommand);
rs.Fill(dt);
myCommand.Dispose();
rs.Dispose();
return dt;
}