首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 操作系统-> 注册表教程
一个通用的分页类_asp.net技巧
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

结合一个存储过程,将分页做成最简单,请看以下源码

此分页类所操作的存储过程#region 此分页类所操作的存储过程
/**//*********************************************************
 *
 * 功能强大,配合以下这个存储过程
 *
 * *******************************************************/
/**//*
-- Pager 1,10,0,0, EmployeeID>2 and EmployeeID<5 , Employees,*,LastName,0
CREATE PROCEDURE Pager
    @PageIndex             int,--索引页 1
    @PageSize              int,--每页数量2
    @RecordCount        int out,--总行数3
    @PageCount             int out,--总页数4
    @WhereCondition         Nvarchar(1000),--查询条件5
    @TableName          nvarchar(500),--查询表名6
    @SelectStr          nvarchar(500) = *,--查询的列7
    @Order              nvarchar(500),--排序的列8
    @OrderType            bit = 0,        -- 设置排序类型, 非 0 值则降序 9
    @Groupby            NVarChar(100) =
AS

declare  @strSQL   nvarchar(2000)     -- 主语句
declare @strTmp   nvarchar(1000)     -- 临时变量
declare @strOrder nvarchar(1000)       -- 排序类型

if @OrderType != 0
begin
    set @strTmp = <(select min
    set @strOrder = order by + @Order + desc
end
else
begin
    set @strTmp = >(select max
    set @strOrder = order by + @Order + asc
end

set @strSQL = select top + str(@PageSize) + + @SelectStr + from
    + @TableName + where + @Order + + @strTmp + ([
    + @Order + ]) from (select top + str((@PageIndex-1)*@PageSize) + [
    + @Order + ] from + @TableName + + @strOrder + ) as tblTmp)
    + @Groupby + @strOrder

if @WhereCondition !=
    set @strSQL = select top + str(@PageSize) + + @SelectStr + from
        + @TableName + where + @Order + + @strTmp + ([
        + @Order + ]) from (select top + str((@PageIndex-1)*@PageSize) + [
        + @Order + ] from + @TableName + where ( + @WhereCondition + )
        + @strOrder + ) as tblTmp) and ( + @WhereCondition + ) + @Groupby + @strOrder

if @PageIndex = 1
begin
    set @strTmp =
    if @WhereCondition !=
        set @strTmp = where ( + @WhereCondition + )

    set @strSQL = select top + str(@PageSize) + + @SelectStr + from
        + @TableName + + @strTmp + + @Groupby + @strOrder
end
exec (@strSQL)
--print @strSQL

    IF @WhereCondition <>
        Begin
            SET @strTmp = SELECT -1 FROM + @TableName + Where + (@WhereCondition)
        End
    ELSE
        Begin
            SET @strTmp = SELECT -1 FROM + @TableName
        End   
    EXEC SP_EXECUTESQL @strTmp
    SET @RecordCount    = @@RowCount
    --    获取总页数
    --    "CEILING"函数:取得不小于某数的最小整数
    SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
GO
*****************************************************************************/
/**//****************************************************************************
 *
 *    用法
 *
 * ***************************************************************************/
 /**//*
        Dim ts As String = Request.Form.Item("txtDate")

        If (ts = "" Or ts Is Nothing) Then
            ts = Request.QueryString("txtDate")
        End If


        Dim ts2 As String = Request.Form.Item("txtDate2")

        If (ts2 = "" Or ts2 Is Nothing) Then
            ts2 = Request.QueryString("txtDate2")
        End If

        Dim ps As String = Request.Form.Item("pageIndex")

        If (ps = "" Or ps Is Nothing) Then
            ps = Request.QueryString("pageIndex")
        End If

        Dim t As Integer = 2
        Dim p As Integer = 1
        If ts Is Nothing Then
            ts = ""
        End If
        If ps Is Nothing Then
            ps = ""
        End If

        If Not (ps = "") Then
            p = Integer.Parse(ps)
        End If

        Dim pager As Pager = New Pager
        pager.PageIndex = p
        pager.PageSize = 20
        pager.PageMode = PageMode.Str
        pager.WhereCondition = "TheDate between convert(datetime," + ts + ") and convert(datetime," + ts2 + ")"
        pager.WhereCondition = " convert(char(10),TheDate,120)=  " + ts + ""
        pager.TableName = "LoadCountlog"
        pager.SelectStr = "*"
        pager.Order = "ID"
        pager.OrderType = False
        Dim dt As System.Data.DataTable = pager.GetDatas(p)
        myDataGrid.DataSource = dt
        myDataGrid.DataBind()
        Dim goUrl As String = "WebForm1.aspx?txtDate=" + ts + "&txtDate2=" + ts2
        Me.Label3.Text = "共:" + pager.PageCount.ToString + "页," + pager.RecordCount.ToString() + "条 <strong>" + pager.OutPager(pager, goUrl, False) + "</strong>"
*/
#endregion
using System;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.Collections;
using System.Text;
namespace solucky
{
    /**//// <summary>
    /// 分页模式
    /// </summary>
    public enum PageMode
    {
        /**//// <summary>
        /// 数字分页
        /// </summary>
        Num    =0,
        /**//// <summary>
        /// 字符分页
        /// </summary>
        Str    =1
    }
    /**//// <summary>
    /// 分页类,能过存储过程进行分页,功能相当强大。
    /// </summary>
   
    public class Pager
    {
        private int pageIndex            = 0;
        private int recordCount            = 0;
        private int pageSize            = 20;
        private int pageCount            = 0;
        private int rowCount            = 0;
        private string tableName        = "";
        private string whereCondition    = "1=1";
        private string selectStr        = "*";
        private string order            = "";
        private string procedure        ="pager";       
        private bool orderType            = true;
        private PageMode pageMode        =PageMode.Num;   
        private string sqlConnectionString                    = ConfigurationSettings.AppSettings["database"];
        private string databaseOwner                        = "dbo";

        数据连接#region 数据连接
        /**//// <summary>
        /// 数据连接字符串
        /// </summary>
        private string SqlConnectionString
        {
            get
            {
                return this.sqlConnectionString;
            }
            set
            {
                this.sqlConnectionString=value;
            }
        }

        /**//// <summary>
        ///获取连接实例
        /// </summary>
        /// <returns></returns>
        private SqlConnection GetSqlConnectionString()
        {
            try
            {
                return new SqlConnection(SqlConnectionString);
            }
            catch
            {
                throw new Exception("SQL Connection String is invalid.");
            }
        }


        /**//// <summary>
        /// 数据对象所有者
        /// </summary>
        private string DatabaseOwner
        {
            get
            {
                return this.databaseOwner;
            }
            set{
                this.databaseOwner=value;
            }
        }

        #endregion

        public Pager()
        {
            //
            // TODO: 在此处添加构造函数逻辑
            //
            //Enum.Parse(tyo
        }
        public Pager(string connstr )
        {
            if (connstr!=null)
                this.SqlConnectionString=connstr;
        }
        #region
        /**//// <summary>
        /// 所要操作的存储过程名称,已有默认的分页存储过程
        /// </summary>
        public string Procedure
        {
            get{
                return this.procedure ;
            }
            set {
                if (value==null || value.Length <=0)
                {
                    this.procedure="pager";
                }
                else
                {
                    this.procedure=value;
                }
            }
        }

        /**//// <summary>
        /// 当前所要显示的页面数
        /// </summary>
        public int PageIndex

        {
            get
            {
                return this.pageIndex;
            }
            set
            {
                this.pageIndex                    = value;
            }
        }

        /**//// <summary>
        /// 总的页面数
        /// </summary>
        public int PageCount
        {
            get
            {
                return this.pageCount;
            }
            set
            {
                this.pageCount                    = value;
            }
        }

        /**//// <summary>
        /// 总行数
        /// </summary>
        public int RecordCount
        {
            get
            {
                return this.recordCount;
            }
            set
            {
                this.recordCount                = value;
            }
        }

        /**//// <summary>
        /// 每页条数
        /// </summary>
        public int PageSize
        {
            get
            {
                return this.pageSize;
            }
            set
            {
                this.pageSize                    = value;
            }
        }

        /**//// <summary>
        /// 表名称
        /// </summary>
        public string TableName
        {
            get
            {
                return tableName;
            }
            set
            {
                this.tableName                    = value;
            }
        }

        /**//// <summary>
        /// 条件查询
        /// </summary>
        public string WhereCondition
        {
            get
            {
                return whereCondition;
            }
            set
            {
                whereCondition                    = value;
            }
        }

        /**//// <summary>
        /// 查询目标(搜索目标),比如:AddTime AS 时间,ID AS 编号
        /// </summary>
        public string SelectStr
        {
            get
            {
                return selectStr;
            }
            set
            {
                selectStr                        = value;
            }
        }

        /**//// <summary>
        /// 排序的列
        /// </summary>
        public string Order
        {
            get
            {
                return order;
            }
            set
            {
                order                            = value;
            }
        }

        /**//// <summary>
        /// 排序类型 true:asc false:desc
        /// </summary>
        public bool OrderType
        {
            get
            {
                return orderType;
            }
            set
            {
                orderType                        = value;
            }
        }   
   
        /**//// <summary>
        /// 分页模式
        /// </summary>
        public PageMode PageMode
        {
            get
            {
                return this.pageMode;
            }
            set
            {
                this.pageMode                    = value;
            }
        }


        /**//// <summary>
        /// 得到当前返回的数量
        /// </summary>
        public int RowCount
        {
            get
            {
                return this.rowCount;
            }
        }

        private string groupby;
        public string Groupby
        {
            get
            {
                return this.groupby;
            }
            set
            {
                this.groupby                = value;
            }
        }

        #endregion
        /**//// <summary>
        /// 分页查寻结果
        /// </summary>
        public DataTable GetDatas(int pageIndex)
        {
            this.pageIndex  = pageIndex;
            Pager pager        = this;
            //pager.pageIndex    = pageIndex;
            DataTable returnTb  = Pagination(ref pager).Tables[0];
            this.rowCount    = returnTb.Rows.Count;
            return returnTb;
        }

        /**//// <summary>
        /// 分页操作存储过程函数
        /// </summary>
        /// <param name="pager"></param>
        /// <returns></returns>
        private  DataSet Pagination(ref Pager pager)
        {
            using ( SqlConnection myConnection                = GetSqlConnectionString() )
            {
                SqlDataAdapter myCommand                    = new SqlDataAdapter(pager.databaseOwner + "."+pager.Procedure, myConnection);
                myCommand.SelectCommand.CommandType            = CommandType.StoredProcedure;

                SqlParameter parameterPageIndex                = new SqlParameter("@PageIndex", SqlDbType.Int);
                parameterPageIndex.Value                    = pager.PageIndex;
                myCommand.SelectCommand.Parameters.Add(parameterPageIndex);

                SqlParameter parameterPageSize                = new SqlParameter("@PageSize", SqlDbType.Int);
                parameterPageSize.Value                        = pager.PageSize;
                myCommand.SelectCommand.Parameters.Add(parameterPageSize);

                SqlParameter parameterRecordCount            = new SqlParameter("@RecordCount", SqlDbType.Int);
                parameterRecordCount.Value                    = 0;
                parameterRecordCount.Direction                = ParameterDirection.InputOutput;
                myCommand.SelectCommand.Parameters.Add(parameterRecordCount);


                SqlParameter parameterPageCount                = new SqlParameter("@PageCount", SqlDbType.Int);
                parameterPageCount.Value                    = 0;
                parameterPageCount.Direction                = ParameterDirection.InputOutput;
                myCommand.SelectCommand.Parameters.Add(parameterPageCount);

                SqlParameter parameterWhereCondition        = new SqlParameter("@WhereCondition", SqlDbType.NVarChar,500);
                parameterWhereCondition.Value                = pager.WhereCondition;
                myCommand.SelectCommand.Parameters.Add(parameterWhereCondition);

                SqlParameter parameterTableName                = new SqlParameter("@TableName", SqlDbType.NVarChar,500);
                parameterTableName.Value                    = pager.TableName;
                myCommand.SelectCommand.Parameters.Add(parameterTableName);

                SqlParameter parameterOrder                    = new SqlParameter("@Order", SqlDbType.NVarChar,500);
                parameterOrder.Value                        = pager.Order;
                myCommand.SelectCommand.Parameters.Add(parameterOrder);

                SqlParameter parameterSelectStr                = new SqlParameter("@SelectStr", SqlDbType.NVarChar,500);
                parameterSelectStr.Value                    = pager.SelectStr;
                myCommand.SelectCommand.Parameters.Add(parameterSelectStr);

                SqlParameter parameterGroupby                = new SqlParameter("@Groupby", SqlDbType.NVarChar, 100);
                parameterGroupby.Value                        = pager.Groupby;
                myCommand.SelectCommand.Parameters.Add(parameterGroupby);

                SqlParameter parameterOrderType                = new SqlParameter("@OrderType", SqlDbType.Bit);
                parameterOrderType.Value                    = pager.OrderType==false?0:1;
                myCommand.SelectCommand.Parameters.Add(parameterOrderType);   
   

                DataSet returnDS                            = new DataSet();

                //SqlDataAdapter sqlDA                        = myCommand.crnew SqlDataAdapter(myCommand);
                myCommand.Fill(returnDS);

                pager.PageCount                                = (int)parameterPageCount.Value;
                pager.RecordCount                            = (int)parameterRecordCount.Value;

                return returnDS;
            }

        }
   
        生成分页#region 生成分页
        /**//// <summary>
        /// 生成分页格式
        /// </summary>
        /// <param name="pager"></param>
        /// <param name="url"></param>
        /// <param name="isBr"></param>
        /// <returns></returns>
        public string OutPager(Pager pager,string url,bool isBr)
        {
            StringBuilder returnOurWml;
            if(isBr)
            {
                returnOurWml= new StringBuilder("["+ pager.PageCount.ToString() + "页," + pager.RecordCount.ToString() +"条]<br/>");
            }
            else
            {
                returnOurWml = new StringBuilder();
            }
            if (pager.PageMode == PageMode.Num)
            {
                //分页每行显示的数量
                int pagersCount = 10;
                int pagers        = 0;
                int startInt    = 1;
                int endInt        = pager.PageCount;
                int i            = 1;

                string endStr   = "";


                if (pager.PageCount>pagersCount)
                {

                    //double        k = ;
                    pagers          = pager.PageIndex / pagersCount;
           
                    if (pagers == 0)
                    {
                        pagers = 1;
                    }
                    else if((pager.PageIndex % pagersCount)!=0)
                    {
                        pagers +=1;
                    }

                    endInt          = pagers * pagersCount;
                    if (pager.PageIndex <= endInt)
                    {
                        startInt = endInt +1 - pagersCount;
                        if (startInt <1)
                        {
                            startInt = 1;
                        }
                    }

                   
                    //显示数量不足时pagersCount
                    if (endInt>=pager.PageCount)
                    {
                        endInt = pager.PageCount;
                    }
                    else
                    {
                        //if (pager.PageIndex)
                        endStr        = " <a href=\"";
                        endStr        += url + "&amp;pageIndex=" + (endInt + 1).ToString()  + "\" title=第"+ (endInt + 1).ToString()+"页>";
                        endStr        += "&gt;&gt;";
                        endStr        += "</a>  ";
                    }

                    if (pagers > 1)
                    {
                        returnOurWml.Append(" <a href=\"");
                        returnOurWml.Append(url + "&amp;pageIndex=" + (startInt - 1).ToString() + "\" title=第"+ (startInt - 1).ToString()+"页>");
                        returnOurWml.Append("&lt;&lt;");
                        returnOurWml.Append("</a>  ");
                    }
                }
               
                for (i = startInt; i<=endInt;i++)
                {
                   
                    if (i!=pager.PageIndex)
                    {
                        returnOurWml.Append(" <a href=\"");
                        returnOurWml.Append(url + "&amp;pageIndex=" + i.ToString() + "\" title=第"+ i.ToString()+"页>");
                        returnOurWml.Append("["+i.ToString() + "]");
                        returnOurWml.Append("</a>  ");
                    }
                    else
                    {
                        returnOurWml.Append("<u>"+ i.ToString() + "</u>");
                    }
                }


                returnOurWml.Append(endStr);


                return returnOurWml.Append("<br/>").ToString();
            }
            else
            {
                if ( pager.PageIndex > 1)
                {
                    returnOurWml.Append(" <a href=\"");
                    returnOurWml.Append(url + "&amp;pageIndex=" + (pager.PageIndex -1).ToString() + "\">");
                    returnOurWml.Append("上一页");
                    returnOurWml.Append("</a>  ");
                }
                if (pager.PageIndex < pager.PageCount)
                {
                    returnOurWml.Append(pager.PageIndex.ToString());
                    returnOurWml.Append(" <a href=\"");
                    returnOurWml.Append(url + "&amp;pageIndex=" + (pager.PageIndex +1).ToString() + "\">");
                    returnOurWml.Append("下一页");
                    returnOurWml.Append("</a>  ");
                }
                return returnOurWml.Append("<br/>").ToString();
            }
        }

        #endregion
    }
}


http://www.cnblogs.com/solucky/archive/2006/09/20/509741.html


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·更改internet explorer的图标
·C#中的类型转换-.NET教程,C#语言
·找回flash的序列号sn
·更改ie的图标
·如何让你的VB6 IDE支持鼠标滚轮(过程)-.NET教程,VB.Net语言
·正则表达式Replace-.NET教程,Asp.Net开发
·Windows 2003下不注册组件用ASP发邮件-ASP教程,邮件相关
·防止ie被恶意修改的初级技巧
·asp.net实现分组全选部分复选框-ASP教程,ASP应用
·清理ie网址列表
最新文章
·seo新手教程:title的写法_seo网站优化
·从注册表下手 切断一切黑客入侵的路径_注册表教程
·用flash 8 as代码写摄像头拍照功能_flash教程
·小站长赚钱思路:ip不到1000,一个月赚940元_网赚技巧
·陈艺光:网络游戏平台与游戏网站实现共赢_站长访谈
·留住访客 如何最优化设计网站的首页?(2)_站长心得
·为什么在google上搜不到我的网页?_google推广
·google的秘密 搜索引擎利用软件的魔力加快奔跑_google推广
·域名与网站排名_站长心得
·怎样避免被搜索引擎视为作弊_站长心得
相关主题
  • 一个通用的表单验证程序-网页设计,HTML/CSS
  • 一个通用的保护ASP系统的方法-ASP教程,安全加密
  • 一个通用的连接池Bean-JSP教程,资料/其它
  • 一个通用的Datagrid导出Excel打印的源函数-.NET教程,数据库应用
  • 一个通用的JSP分页程序-JSP教程,Jsp/Servlet
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭