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

日期: 2008-08-06 作者:晴穹 来源:TechTarget中国 英文

  在以下的文章中,我将以“办公自动化”系统为例,探讨如何在有着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万条记录’)

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

作者

晴穹
晴穹

相关推荐