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

相关文章

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA