关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » 网站维护 »通用SQL存储过程分页以及asp.net后台调用

    通用SQL存储过程分页以及asp.net后台调用

    2015-09-10 00:00:00 出处:ITJS
    分享

    创建表格并添加300万数据

    use Stored CREATE TABLE UserInfo(  --创建表 id int  IDENTITY(1,1) PRIMARY KEY not null,--添加主键和标识列 UserName varchar(50)  )   declare @i int  --添加3百万数据,大概4分钟时间 set @i=1 while @i<3000000 begin insert into UserInfo (UserName) values(@i) set @i=@i+1 end 

    存储过程T-SQL

    USE [Stored] GO /****** Object:  StoredProcedure [dbo].[GetDataList]    Script Date: 08/17/2015 16:40:21 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER  PROCEDURE [dbo].[GetDataList] (  @TableName  varchar(5000),       --表名  @Fields varchar(5000) = '*',     --字段名(全部字段为*)  @OrderField varchar(5000),       --排序字段(必须!支持多字段)  @OrderType varchar(5000),        --排序类型  @sqlWhere varchar(5000) = Null,  --条件语句(不用加where)  @pageSize int,                   --每页多少条记录  @pageIndex int = 1 ,             --指定当前为第几页  @TotalPage int output,           --返回总页数   @totalRecord int output       --计算总记录数              --返回总记录数  ) as begin    Begin Tran --开始事务    Declare @sql nvarchar(4000);          Declare   @sql nvarchar(500)=''       if (@SqlWhere='' or @sqlWhere=NULL)         set @sql = 'select @totalRecord = count(*) from ' + @TableName     else         set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' where ' + @sqlWhere               EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--计算总记录数                             --计算总页数     select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)    if (@SqlWhere='' or @sqlWhere=NULL)         set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField +' ' + @Ordertype+' ) as rowId,' + @Fields + ' from ' + @TableName      else         set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField +' ' + @Ordertype+'  ) as rowId,' + @Fields + ' from ' + @TableName + ' where ' + @SqlWhere      --处理页数超出范围情况     if @PageIndex<=0          Set @pageIndex = 1          if @pageIndex>@TotalPage         Set @pageIndex = @TotalPage     --处理开始点和结束点     Declare @StartRecord int     Declare @EndRecord int          set @StartRecord = (@pageIndex-1)*@PageSize + 1     set @EndRecord = @StartRecord + @pageSize - 1    --继续合成sql语句     set @Sql = @Sql + ') as ' + @TableName + ' where rowid between ' + Convert(varchar(50),@StartRecord) + ' and ' +  Convert(varchar(50),@EndRecord)      --print @Sql             Exec(@Sql)     ---------------------------------------------------     If @@Error <> 0       Begin         RollBack Tran         Return -1       End      Else       Begin         Commit Tran         Return @totalRecord ---返回记录总数       End     end  --exec GetDataList 'Userinfo','*','id','desc','',10,1,3,3000000 

    前台页面Default2.aspx

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server">     <title></title> </head> <body>     <form id="form1" runat="server">     <div>      <asp:GridView ID="GridView1" runat="server">         </asp:GridView>        <asp:Label ID="lbl_page" runat="server" Text="Label"></asp:Label>     </div>     </form> </body> </html> 

    后台CS代码Default2.aspx.cs

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using System.Data; using System.Data.SqlClient; using System.Configuration; using System.Text;   public partial class Default2 : System.Web.UI.Page {        private int PageIndex = 0;//当前页码     private int PageSize = 50;//每页几条记录     private int TotalPage = 1;//总分页数     private int TotalRecord = 0;//总记录     private string OrderType = " desc";//排序方式 默认正序     protected void Page_Load(object sender, EventArgs e)     {         if (!IsPostBack)         {             GetParams();             DataSet ds = PageData("UserInfo", "*", "id", OrderType, "", PageSize, PageIndex, out TotalPage, out TotalRecord);             GridView1.DataSource = ds;             GridView1.DataBind();             lbl_page.Text = GetDivPager("", ds);         }     }      //数据库连接字符     public static string StrConn()     {         //return string.Format("{0}","server=.;database=Stored;user=sa;password=123456");         return ConfigurationSettings.AppSettings["ConnString"].ToString();     }     //Get方式获得下一页     private void GetParams()     {         if (!String.IsNullOrEmpty(Request["page"]))         {             PageIndex = Convert.ToInt32(Request["Page"]);         }         else         {             PageIndex = 1;         }     }     #region 获得分页字符     public string GetDivPager(string queryString, DataSet ds)     {         StringBuilder sp = new StringBuilder();         int TotalCount = TotalRecord;         int rowCount = TotalPage;         if (ds != null)         {             sp.AppendFormat("  <p>总记录:<span id="sum">{0}</span>", TotalCount);             sp.AppendFormat("  页码:<em><b id="current">{0}</b>/<span id="count">{1}</span></em> ", PageIndex, rowCount);             sp.AppendFormat("  每页:<span id="eachPage">{0}</span></p> ", PageSize);                          sp.AppendFormat("  <a  href='{0}'>首页</a> ", " page=1" + queryString);             if (PageIndex > 1)             {                 sp.AppendFormat("  <a href='{0}'>< 上一页 </a>", " page=" + (PageIndex - 1) + queryString);             }             int temp = 0;             int loopc = rowCount > 10   10 : rowCount;             for (int i = 0; i < loopc; i++)             {                 temp = i + 1;                 if (PageIndex > 10) { temp = (PageIndex - 10) + i + 1; }                 sp.AppendFormat("  <a class="{0}" href='{1}'>{2}</a>", PageIndex == temp   "active" : "", " page=" + temp + queryString, temp);             }             if (PageIndex != rowCount)             {                 sp.AppendFormat("  <a href='{0}'>下一页 ></a>", " page=" + (PageIndex + 1) + queryString);             }             sp.AppendFormat("  <a href='{0}'>尾页</a>", " page=" + rowCount + queryString);                    }         else         {             ds = null;         }         return sp.ToString();     }     #endregion     #region 获取分页的数据     /// <summary>     /// 获取分页的数据     /// </summary>     /// <param name="TblName">数据表名</param>     /// <param name="Fields">要读取的字段</param>     /// <param name="OrderField">排序字段</param>     /// <param name="OrderType">排序方式</param>     /// <param name="SqlWhere">查询条件</param>     /// <param name="PageSize">每页显示多少条数据</param>     /// <param name="pageIndex">当前页码</param>     /// <param name="TotalPage">返回值,共有多少页</param>     /// <param name="TotalRecord">返回值,总有多少条记录</param>     /// <returns></returns>     public static DataSet PageData(string TblName, string Fields, string OrderField, string OrderType, string SqlWhere, int PageSize, int pageIndex, out int TotalPage, out int TotalRecord)     {          SqlConnection conn = new SqlConnection(StrConn());         SqlCommand comm = new SqlCommand("GetDataList", conn);          comm.Parameters.Add(new SqlParameter("@TableName", SqlDbType.NVarChar, 100)).Value = TblName;         comm.Parameters.Add(new SqlParameter("@Fields", SqlDbType.NVarChar, 1000)).Value = Fields;         comm.Parameters.Add(new SqlParameter("@OrderField", SqlDbType.NVarChar, 1000)).Value = OrderField;         comm.Parameters.Add(new SqlParameter("@OrderType", SqlDbType.NVarChar, 1000)).Value = OrderType;         comm.Parameters.Add(new SqlParameter("@sqlWhere", SqlDbType.NVarChar, 1000)).Value = SqlWhere;         comm.Parameters.Add(new SqlParameter("@pageSize", SqlDbType.Int)).Value = PageSize;         comm.Parameters.Add(new SqlParameter("@pageIndex", SqlDbType.Int)).Value = pageIndex;         comm.Parameters.Add(new SqlParameter("@TotalPage", SqlDbType.Int));          comm.Parameters["@TotalPage"].Direction = ParameterDirection.Output;//获得out出来的参数值          comm.Parameters.Add(new SqlParameter("@totalRecord", SqlDbType.Int));         comm.Parameters["@totalRecord"].Direction = ParameterDirection.Output;          comm.CommandType = CommandType.StoredProcedure;          SqlDataAdapter dataAdapter = new SqlDataAdapter(comm);         DataSet ds = new DataSet();         dataAdapter.Fill(ds);          TotalPage = (int)comm.Parameters["@TotalPage"].Value;         TotalRecord = (int)comm.Parameters["@totalRecord"].Value;          conn.Close();         conn.Dispose();         comm.Dispose();                  return ds;     }     #endregion } 

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    抖音安全与信任开放日:揭秘推荐算法,告别单一标签依赖

    ultraedit编辑器打开文件时,总是提示是否转换为DOS格式,如何关闭?

    Cornell大神Kleinberg的经典教材《算法设计》是最好入门的算法教材

    从 Microsoft 下载中心安装 Windows 7 SP1 和 Windows Server 2008 R2 SP1 之前要执行的步骤

    Llama 2基于UCloud UK8S的创新应用

    火山引擎DataTester:如何使用A/B测试优化全域营销效果

    腾讯云、移动云继阿里云降价后宣布大幅度降价

    字节跳动数据平台论文被ICDE2023国际顶会收录,将通过火山引擎开放相关成果

    这个话题被围观超10000次,火山引擎VeDI如此解答

    误删库怎么办?火山引擎DataLeap“3招”守护数据安全

    IT头条

    平替CUDA!摩尔线程发布MUSA 4性能分析工具

    00:43

    三起案件揭开侵犯个人信息犯罪的黑灰产业链

    13:59

    百度三年开放2.1万实习岗,全力培育AI领域未来领袖

    00:36

    工信部:一季度,电信业务总量同比增长7.7%,业务收入累计完成4469亿元

    23:42

    Gartner:2024年全球半导体营收6559亿美元,AI助力英伟达首登榜首

    18:04

    技术热点

    iOS 8 中如何集成 Touch ID 功能

    windows7系统中鼠标滑轮键(中键)的快捷应用

    MySQL数据库的23个特别注意的安全事项

    Kruskal 最小生成树算法

    Ubuntu 14.10上安装新的字体图文教程

    Ubuntu14更新后无法进入系统卡在光标界面解怎么办?

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。