asp.net 如何让处理绑定10万条以上的数据
2009-06-22 17:10
246 查看
只能用存储过程分页,每次只取一页的数据,下面这个存储过程承受30万的数据量完全没问题。
--分页存储过程
CREATE PROC Common_Page
@RecordCount INT,
@QueryStr NVARCHAR(100)='table1',--表名、视图名、查询语句
@PageSize INT = 20, --每页的大小(行数)
@PageCurrent INT = 0, --要显示的页 从0开始
@FdShow NVARCHAR (1000)='*', --要显示的字段列表
@IdentityStr NVARCHAR (100)='id', --主键
@WhereStr NVARCHAR (1000)='1=1',
@FdOrder NVARCHAR(100)='desc' --排序 只能取desc或者asc
AS
DECLARE
@sql NVARCHAR(4000)
IF @WhereStr = ''
BEGIN
SET @WhereStr = '1=1'
END
SET @WhereStr = ' ( ' + @WhereStr + ' ) '
IF @PageCurrent = 0
BEGIN
SET @sql = 'SELECT TOP ' + CAST(@PageSize AS NVARCHAR(10)) + ' ' + @FdShow + ' from ' +@QueryStr + ' where ' + @WhereStr + ' order by ' + @IdentityStr + ' ' + @FdOrder
END
ELSE
BEGIN
IF UPPER(@FdOrder) = 'DESC'
BEGIN
SET @sql = 'SELECT TOP ' + CAST(@PageSize AS NVARCHAR(10)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' and ' + @IdentityStr + '< ( select min(' + @IdentityStr + ') from (SELECT TOP ' + CAST(@PageSize*@PageCurrent AS NVARCHAR(10)) + ' ' + @IdentityStr+ ' FROM ' + @QueryStr + ' WHERE ' + @WhereStr + ' ORDER BY ' + @IdentityStr + ' DESC) AS t) ORDER BY ' + @IdentityStr + ' DESC'
END
ELSE
BEGIN
SET @sql = 'SELECT TOP ' + CAST(@PageSize AS NVARCHAR(10)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' and ' + @IdentityStr + '> ( select max(' + @IdentityStr + ') from (select top ' + CAST(@PageSize*@PageCurrent AS NVARCHAR(10)) + ' ' + @IdentityStr + ' FROM ' + @QueryStr + ' WHERE ' + @WhereStr + ' ORDER BY ' + @IdentityStr + ' ASC) AS t) ORDER BY ' + @IdentityStr + ' ASC'
END
END
--print @sql
EXECUTE sp_executesql @sql
IF(@RecordCount is null or @RecordCount<0)
BEGIN
DECLARE @tsql NVARCHAR(1000)
SET @tsql=N'SELECT @RecordCount = count(*) FROM ' + @QueryStr + ' WHERE ' + @WhereStr
EXEC sp_executesql @tsql,N'@RecordCount INT OUTPUT',@RecordCount OUTPUT
SELECT @RecordCount
END
GO
转载地址:http://blog.csdn.net/chenjianyong94/archive/2009/06/19/4281871.aspx
--分页存储过程
CREATE PROC Common_Page
@RecordCount INT,
@QueryStr NVARCHAR(100)='table1',--表名、视图名、查询语句
@PageSize INT = 20, --每页的大小(行数)
@PageCurrent INT = 0, --要显示的页 从0开始
@FdShow NVARCHAR (1000)='*', --要显示的字段列表
@IdentityStr NVARCHAR (100)='id', --主键
@WhereStr NVARCHAR (1000)='1=1',
@FdOrder NVARCHAR(100)='desc' --排序 只能取desc或者asc
AS
DECLARE
@sql NVARCHAR(4000)
IF @WhereStr = ''
BEGIN
SET @WhereStr = '1=1'
END
SET @WhereStr = ' ( ' + @WhereStr + ' ) '
IF @PageCurrent = 0
BEGIN
SET @sql = 'SELECT TOP ' + CAST(@PageSize AS NVARCHAR(10)) + ' ' + @FdShow + ' from ' +@QueryStr + ' where ' + @WhereStr + ' order by ' + @IdentityStr + ' ' + @FdOrder
END
ELSE
BEGIN
IF UPPER(@FdOrder) = 'DESC'
BEGIN
SET @sql = 'SELECT TOP ' + CAST(@PageSize AS NVARCHAR(10)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' and ' + @IdentityStr + '< ( select min(' + @IdentityStr + ') from (SELECT TOP ' + CAST(@PageSize*@PageCurrent AS NVARCHAR(10)) + ' ' + @IdentityStr+ ' FROM ' + @QueryStr + ' WHERE ' + @WhereStr + ' ORDER BY ' + @IdentityStr + ' DESC) AS t) ORDER BY ' + @IdentityStr + ' DESC'
END
ELSE
BEGIN
SET @sql = 'SELECT TOP ' + CAST(@PageSize AS NVARCHAR(10)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' and ' + @IdentityStr + '> ( select max(' + @IdentityStr + ') from (select top ' + CAST(@PageSize*@PageCurrent AS NVARCHAR(10)) + ' ' + @IdentityStr + ' FROM ' + @QueryStr + ' WHERE ' + @WhereStr + ' ORDER BY ' + @IdentityStr + ' ASC) AS t) ORDER BY ' + @IdentityStr + ' ASC'
END
END
--print @sql
EXECUTE sp_executesql @sql
IF(@RecordCount is null or @RecordCount<0)
BEGIN
DECLARE @tsql NVARCHAR(1000)
SET @tsql=N'SELECT @RecordCount = count(*) FROM ' + @QueryStr + ' WHERE ' + @WhereStr
EXEC sp_executesql @tsql,N'@RecordCount INT OUTPUT',@RecordCount OUTPUT
SELECT @RecordCount
END
GO
转载地址:http://blog.csdn.net/chenjianyong94/archive/2009/06/19/4281871.aspx
相关文章推荐
- ASP.NET 中如何在使用Eval()绑定数据时使用三元运算符
- ASP.NET 2.0的 GridView中模板列绑定DropDownList的数据处理
- Asp.net Gridview绑定空数据, 如何显示标题
- ASP.NET中绑定数据控件OnClientClick事件Eval函数解析错误的处理
- ASP.NET MVC AJAX实现 以及如何处理json数据,简介
- 摘要:了解 ASP.NET 2.0 中的用于生成自定义数据绑定控件的工具是如何演变的
- asp.net:百万级以上的数据处理
- ASP.NET 中如何在使用Eval()绑定数据时使用三元运算符
- ASP.NET 中如何在使用Eval()绑定数据时使用三元运算符
- 一起谈.NET技术,ASP.NET Eval如何进行数据绑定
- asp.net,datalist 控件 绑定数据,如何删除数据的刷新。
- asp.net 绑定数据的处理小例
- 菜鸟学Asp.Net——GridView控件之RowDataBind事件中如何获取已绑定的数据
- ASP.NET Eval如何进行数据绑定
- 转载的 asp.net:百万级以上的数据处理
- ASP.NET Eval如何进行数据绑定
- asp.net 数据绑定时对数据列做个性化处理
- ASP.NET前台如何调用后台定义的变量即数据的绑定详解
- 如何:在 ASP.NET 网页中对事件处理程序进行运行时动态绑定