ASP.NET GridView 显示超大表 记录太多,一次从数据库中读出 太耗资源 怎么办?

ASP.NETGridView显示超大表记录太多,一次从数据库中读出太耗资源怎么办?说答案的时候简单说明一下用法,最好举个例子..别太笼统...... ASP.NET GridView 显示超大表 记录太多,一次从数据库中读出 太耗资源 怎么办?
说答案的时候简单说明一下用法,最好举个例子..别太笼统...
展开
 我来答
love_dou_dou
2010-07-05 · 超过15用户采纳过TA的回答
知道答主
回答量:111
采纳率:100%
帮助的人:34.6万
展开全部
不知道你说的是不是分页问题:
如果是分页的话可以用存储过程来实现
USE [HegoFA_Mng]
GO
/****** 对象: StoredProcedure [dbo].[PS_Page] 脚本日期: 07/05/2010 15:26:28 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[PS_Page]
@tblName varchar(255), -- 表名
@fldName varchar(255), -- 主键或者排序字段名
@PageSize int = 20, -- 页尺寸
@PageIndex int = 1, -- 页码
@IsReCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1000) = '', -- 查询条件 (注意: 不要加 where)
@strSelectField varchar(500) --查询的列(所有列是*,其他是code,name,type)
AS
BEGIN
declare @strSQL varchar(6000) -- 主语句
declare @strTotal varchar(2000) -- 获取记录数合计语句
declare @strTmp varchar(1000) -- 临时变量
declare @strOrder varchar(400) -- 排序类型

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

set @strSQL = 'select top ' + str(@PageSize)+ ' ' + @strSelectField + ' from ['
+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
+ @fldName + '] from [' + @tblName + ']' + @strOrder + ') as tblTmp)'
+ @strOrder

if @strWhere != ''
set @strSQL = 'select top ' + str(@PageSize)+ ' ' + @strSelectField + ' from ['
+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
+ @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '
+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder

if @PageIndex = 1
begin
set @strTmp =''
if @strWhere != ''
set @strTmp = ' where ' + @strWhere

set @strSQL = 'select top ' + str(@PageSize)+ ' ' + @strSelectField + ' from ['
+ @tblName + ']' + @strTmp + ' ' + @strOrder

end

if @strWhere != ''
set @strTotal = 'select count(*) as Total from [' + @tblName + ']'+' where ' + @strWhere
else
set @strTotal = 'select count(*) as Total from [' + @tblName + ']'

exec (@strSQL)
if @IsReCount != 0
exec (@strTotal)
END

不会调用在说,我这里有代码
AnotherSilence
2010-07-05 · 超过26用户采纳过TA的回答
知道答主
回答量:71
采纳率:0%
帮助的人:82.2万
展开全部
最基本的分页技术,方法好多,用“数据库 分页”或“asp.net 分页“ 或”分页算法“ google ,会有好多答案。

比如自己以前总结的这篇:http://hi.baidu.com/anothersilence/blog/item/53472e072fb39370020881e6.html
供参考。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
广州方讯科技
2010-07-12 · TA获得超过346个赞
知道小有建树答主
回答量:316
采纳率:100%
帮助的人:225万
展开全部
这个当然得使用分页功能啦,GridView控件自带分页功能,实现起来很容易的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友6f75ac8fa
2010-07-05 · TA获得超过2513个赞
知道大有可为答主
回答量:1.3万
采纳率:0%
帮助的人:4044万
展开全部
分页
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
kissnni
2010-07-05 · TA获得超过548个赞
知道小有建树答主
回答量:1335
采纳率:50%
帮助的人:541万
展开全部
没什么好办法。数据库做好视图。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式