晨风资讯网
新闻资讯网络冲浪网页设计网络编程图形图像数据库网络媒体服务器网络安全网站运营软件教程黑客认证Wap技术
教程搜索
教程搜索:
  首页 > 数 据 库 > MS_SQL > 正文  

千万级数据库高速分页显示(讨论)
日期:2006-3-30 11:14:40 来源: 作者: 浏览:

        set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
             + @tblName + ']' + @strTmp + ' ' + @strOrder
   end
  else
   begin
    --如果是降序查询……
    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

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

 
   end
end

exec (@strSQL)
GO
----------------------------------------------
我也来一下,这个可以实现多表查询。

-- =============================================
-- 数据分页的存储过程
-- 记录号在 TempIDKey_Num 字段中
-- 调用的例子: 表示 从结果中第3行开始的5条记录。
-- T-SQL:EXECUTE proTest N'select top 100 percent * from orders', 3,5
-- ASP.NET(C#):
-- <%@ Page Language="C#" %>
-- <%@ Import Namespace="System.Data" %>
-- <%@ Import Namespace="System.Data.SqlClient" %>
-- <Script Runat="Server">
-- void Page_Load( Object s, EventArgs e )
-- {
-- SqlConnection myConnection;
-- SqlCommand myCommand;
-- myConnection = new SqlConnection( "Server=(local);uid=sa;pwd=11;Database=Northwind" );
-- myCommand = new SqlCommand( "proTest", myConnection );
-- myCommand.CommandType = CommandType.StoredProcedure;
-- myCommand.Parameters.Add("@strSql","Select top 30 * from orders");
-- myCommand.Parameters.Add("@startRow",10);
-- myCommand.Parameters.Add("@maxRows",15);

本教程共4页,当前在第3页  1  2  3  4  


上一篇: 找出存放用户名和密码的表 下一篇:

使用sql server中的全文索引

返回列表 打印此页 加入收藏 资讯论坛 关闭窗口 点击复制本页地址,发送给QQ/MSN好友
关于我们 - 联系我们 - 版权声明 - 帮助(?) - 广告服务 - 友情链接 - 服务项目 - 人才招聘
2003-2008 版权所有 © 晨风资讯网 未经授权禁止复制或建立镜像
CopyRight 2003-2008 www.Net118.com,All Rights Reserved.Design By ChenFeng Network Studio