Eric的超高效数据分页(图示+代码) ^_^

2024-02-17 10:58

本文主要是介绍Eric的超高效数据分页(图示+代码) ^_^,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

运行截图:



数据表结构:
megaid int IDENTITY (1, 1) NOT NULL PRIMARY KEY  CLUSTERED
megaguid char (36) NOT NULL INDEX


数据生成脚本:
DECLARE  @i  int
SET  @i  =   1
WHILE  @i  <   1000001
    
BEGIN
        
INSERT   INTO  megatable (megaguid)  VALUES ( NEWID ())
        
SET  @i  =  @i  +   1
    
END
GO


C#代码:
        DateTime startTime;

        
void  Page_Init(Object sender, EventArgs e)
        
{
            startTime 
= DateTime.Now;
        }


        
protected   override   void  Render(HtmlTextWriter writer)  
        
{
            
base.Render(writer); 
            Response.Write(
"本页执行时间: "  +  (DateTime.Now - startTime));  
        }


        
int  records  =   10000 ;
        
int  pages  =   10 ;
        
int  pageSize  =   15 ;
        SqlConnection conn 
=   new  SqlConnection( " Server=(local);Database=megadata;User Id=sa;Password=xxx " );

        
void  Page_Load( object  sender, EventArgs e)
        
{
            
if (!IsPostBack)
            
{
                dgBind(getSqlString(
1));
            }


            
int firstPage = int.Parse(hidFirstPage.Value);
            pnlButtons.Controls.Add(getPager(firstPage));
            lblPrompt.Text 
= "数据提取范围: <B>SELECT TOP " + records.ToString() + " megaid FROM megatable ORDER BY megaguid</B>";
        }


        
string  getSqlString( int  selectedPage)
        
{
            
string[] idsStrArray;
            
string sqlStr;

            
if (Session["idStr"!= null)
            
{
                idsStrArray 
= Session["idStr"].ToString().Split('#');
            }

            
else
            
{
                sqlStr 
= "SELECT TOP " + records.ToString() + " megaid FROM megatable ORDER BY megaguid";
                SqlCommand cmd 
= new SqlCommand(sqlStr, conn);
                conn.Open();
                SqlDataReader dr 
= cmd.ExecuteReader();
                StringBuilder sb 
= new StringBuilder("");
                
int n = 1;

                
while (dr.Read())
                
{
                    
if (n % pageSize == 0)
                    
{
                        sb.Append(dr[
0].ToString() + "#");
                    }

                    
else
                    
{
                        sb.Append(dr[
0].ToString() + ",");
                    }

                    
                    n
++;
                }


                dr.Close();
                conn.Close();
                sb.Remove(sb.Length 
- 11);
                idsStrArray 
= sb.ToString().Split('#');
                Session[
"idStr"= sb.ToString();
            }


            hidPageCount.Value 
= idsStrArray.Length.ToString();
            sqlStr 
= "SELECT megaid, megaguid FROM megatable WHERE megaid IN (" + idsStrArray[selectedPage - 1+ "";
            sqlStr 
+= "ORDER BY megaguid";
            
return sqlStr;
        }

        
        Panel getPager(
int  firstPage)
        
{
            
int pageCount = int.Parse(hidPageCount.Value);
            Panel pnlPager 
= new Panel();
            pnlPager.Controls.Add(
new LiteralControl("<BR> 共" + pageCount.ToString() + "页 "));
            pnlPager.Controls.Add(getLinkButton(
"Fst""首页""pgBtn""1"));
            pnlPager.Controls.Add(
new LiteralControl(" "));

            
if (firstPage > 0)
            
{
                pnlPager.Controls.Add(getLinkButton(
"Pre""" + pages.ToString() + """pgBtn", (firstPage - pages + 1).ToString()));
                pnlPager.Controls.Add(
new LiteralControl(" "));
            }


            
for (int i = firstPage + 1; i < firstPage + pages + 1; i++)
            
{
                
if (i > pageCount)
                
{
                    
break;
                }

                
                pnlPager.Controls.Add(getLinkButton(i.ToString(), 
"[" + i.ToString() + "]""pgBtn", i.ToString()));
                pnlPager.Controls.Add(
new LiteralControl(" "));
            }


            
if (firstPage + pages < pageCount)
            
{
                pnlPager.Controls.Add(getLinkButton(
"Nxt""" + pages.ToString() + """pgBtn", (firstPage + pages + 1).ToString()));
                pnlPager.Controls.Add(
new LiteralControl(" "));
            }


            pnlPager.Controls.Add(getLinkButton(
"Lst""末页""pgBtn", pageCount.ToString()));
            
return pnlPager;
        }


        LinkButton getLinkButton(
string  lbId,  string  lbText,  string  lbCmdName,  string  lbCmdArg)
        
{
            LinkButton lb 
= new LinkButton();
            lb.ID 
= lbCmdName + lbId;
            lb.Text 
= lbText;
            lb.CommandName 
= lbCmdName;
            lb.CommandArgument 
= lbCmdArg;
            lb.Command 
+= new CommandEventHandler(pageTurn);
            
return lb;
        }

        
        
void  pageTurn( object  sender, CommandEventArgs e)
        
{
            LinkButton lb 
= (LinkButton)sender;
            
int selectedPage = int.Parse(lb.CommandArgument);
            
int firstPage = selectedPage / pages * pages;
            firstPage 
= (selectedPage % pages == 0? (firstPage - pages) : firstPage;
            hidFirstPage.Value 
= firstPage.ToString();
            dgBind(getSqlString(selectedPage));
            pnlButtons.Controls.RemoveAt(pnlButtons.Controls.Count 
- 1);
            pnlButtons.Controls.Add(getPager(firstPage));
            lb 
= (LinkButton)pnlButtons.Controls[pnlButtons.Controls.Count - 1].FindControl("pgBtn" + selectedPage.ToString());
            lb.Enabled 
= false;
        }

        
        
void  dgBind( string  sqlStr)
        
{
            SqlDataAdapter da 
= new SqlDataAdapter(sqlStr, conn);
            DataTable dt 
= new DataTable();
            conn.Open();
            da.Fill(dt);
            conn.Close();
            da.Dispose();
            dg.DataSource 
= dt;
            dg.DataBind();
        }


        
void  dg_ItemDataBound( object  sender, DataGridItemEventArgs e)
        
{
            dg.Controls[
0].EnableViewState = false;
        }

ASPX代码:
<% @ Import Namespace="System.Text"  %>
<% @ Import Namespace="System.Data.SqlClient"  %>
<% @ Import Namespace="System.Data"  %>
<% @ Page Language="C#"  %>
<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd" >
< HTML >
    
< HEAD >
        
< TITLE > Pager </ TITLE >
        
< SCRIPT  runat ="server" >
        
//插入上面的C#代码
        
</ SCRIPT >
        
< STYLE > BODY { FONT-SIZE: 9pt; FONT-FAMILY: Tahoma,宋体; TEXT-ALIGN: center }
    TD 
{ FONT-SIZE: 9pt; FONT-FAMILY: Tahoma,宋体; TEXT-ALIGN: center }
    
</ STYLE >
    
</ HEAD >
    
< BODY >
        
< FORM  id ="form1"  runat ="server" >
            
< DIV >
                
< ASP:LABEL  id ="lblPrompt"  runat ="server"  text ="?"  enableviewstate ="False"  enabletheming ="True" ></ ASP:LABEL >
                
< BR >
                
< ASP:PANEL  id ="pnlButtons"  runat ="server"  width ="560px" >
                    
< INPUT  id ="hidFirstPage"  type ="hidden"  value ="0"  runat ="server" >< INPUT  id ="hidPageCount"  type ="hidden"  runat ="server" >
                    
< ASP:DATAGRID  id ="dg"  runat ="server"  width ="100%"  onitemdatabound ="dg_ItemDataBound"  cellpadding ="4"
                        backcolor
="White"  borderwidth ="1px"  borderstyle ="None"  bordercolor ="#CC9966"  autogeneratecolumns ="False"
                        pagesize
="5" >
                        
< FOOTERSTYLE  forecolor ="#330099"  backcolor ="#FFFFCC" ></ FOOTERSTYLE >
                        
< HEADERSTYLE  font-bold ="True"  forecolor ="#FFFFCC"  backcolor ="#990000" ></ HEADERSTYLE >
                        
< PAGERSTYLE  horizontalalign ="Center"  forecolor ="#330099"  backcolor ="#FFFFCC" ></ PAGERSTYLE >
                        
< SELECTEDITEMSTYLE  font-bold ="True"  forecolor ="#663399"  backcolor ="#FFCC66" ></ SELECTEDITEMSTYLE >
                        
< ITEMSTYLE  forecolor ="#330099"  backcolor ="White" ></ ITEMSTYLE >
                        
< COLUMNS >
                            
< ASP:BOUNDCOLUMN  datafield ="megaid"  headertext ="MegaID" ></ ASP:BOUNDCOLUMN >
                            
< ASP:BOUNDCOLUMN  datafield ="megaguid"  headertext ="MegaGUID" ></ ASP:BOUNDCOLUMN >
                        
</ COLUMNS >
                    
</ ASP:DATAGRID >
                
</ ASP:PANEL ></ DIV >
            
< BR >
            
< ASP:HYPERLINK  id ="lnkReload"  runat ="server"  width ="80px"  navigateurl ="Pager.aspx"  enableviewstate ="False" > 重载 </ ASP:HYPERLINK >
        
</ FORM >
    
</ BODY >
</ HTML >

这篇关于Eric的超高效数据分页(图示+代码) ^_^的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/717564

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的