[ 登录 ][ 注册 ] 天极传媒: 比特网 | 天极网 | IT专家网 | IT商网 | 52PK游戏网 | 手机天极 | IT分众 |
您现在的位置: IT专家网 > 数据库子站 > 数据库技巧

海量数据库查询优化及分页算法

作者: 晴穹,  出处:blog, 责任编辑: 王晓晨, 
2008-08-07 08:01
  本文将以“办公自动化”系统为例,探讨如何在有着1000万条数据的MS SQL SERVER数据库中实现快速的数据提取和数据分页。

  在以下的文章中,我将以“办公自动化”系统为例,探讨如何在有着1000万条数据的MS SQL SERVER数据库中实现快速的数据提取和数据分页。以下代码说明了我们实例中数据库的“红头文件”一表的部分数据结构:  

CREATE TABLE [dbo].[TGongwen] ( --TGongwen是红头文件表名
[Gid] [int] IDENTITY (1, 1) NOT NULL ,

  --本表的id号,也是主键

[title] [varchar] (80) COLLATE Chinese_PRC_CI_AS NULL ,

  --红头文件的标题

[fariqi] [datetime] NULL ,

  --发布日期 

[neibuYonghu] [varchar] (70) COLLATE Chinese_PRC_CI_AS NULL ,

  --发布用户

[reader] [varchar] (900) COLLATE Chinese_PRC_CI_AS NULL ,

  --需要浏览的用户。每个用户中间用分隔符“,”分开  

ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO

  下面,我们来往数据库中添加1000万条数据: 

declare @i int
  set @i=1
  while @i<=250000
  begin

  insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-2-5','通信科','通信科,办公室,王局长,刘局长,张局长,admin,刑侦支队,特勤支队,交巡警支队,经侦支队,户政科,治安支队,外事科','这是最先的25万条记录')

set @i=@i+1
  end
  GO
  declare @i int
  set @i=1
  while @i<=250000
  begin

  insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-9-16','办公室','办公室,通信科,王局长,刘局长,张局长,admin,刑侦支队,特勤支队,交巡警支队,经侦支队,户政科,外事科','这是中间的25万条记录') 

set @i=@i+1
  end
  GO
  declare @h int
  set @h=1
  while @h<=100
  begin
  declare @i int
  set @i=2002
  while @i<=2003
  begin
  declare @j int
  set @j=0
  while @j<50
  begin
  declare @k int
  set @k=0
  while @k<50
  begin

  insert into Tgongwen(fariqi,neibuyonghu,reader,title) values(cast(@i as varchar(4))+'-8-15 3:'+cast(@j as varchar(2))+':'+cast(@j as varchar(2)),'通信科','办公室,通信科,王局长,刘局长,张局长,admin,刑侦支队,特勤支队,交巡警支队,经侦支队,户政科,外事科','这是最后的50万条记录')

共7页。 1 2 3 4 5 6 :

网友评论

笔名 
请您注意:遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。    IT专家网友拥有管理笔名和留言的一切权利。

邮件订阅