亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

通用SQL存儲過程分頁以及asp.net后臺調用

2024-07-21 02:46:03
字體:
來源:轉載
供稿:網友
通用SQL存儲過程分頁以及asp.net后臺調用

創建表格并添加300萬數據

use StoredCREATE TABLE UserInfo(  --創建表id int  IDENTITY(1,1) PRIMARY KEY not null,--添加主鍵和標識列UserName varchar(50) ) declare @i int  --添加3百萬數據,大概4分鐘時間set @i=1while @i<3000000begininsert into UserInfo (UserName) values(@i)set @i=@i+1end

存儲過程T-SQL

USE [Stored]GO/****** Object:  StoredProcedure [dbo].[GetDataList]    Script Date: 08/17/2015 16:40:21 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOALTER  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       --計算總記錄數              --返回總記錄數 )asbegin    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", SqlD
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美精品一区二区三区介绍| 国内精品400部情侣激情| 中文字幕九色91在线| 国产成人精品免费视频| 国产欧美日韩中文字幕| 九九热精品视频| 97精品久久久| 性欧美xxxx视频在线观看| 亚洲高清久久网| 国产精品爱久久久久久久| 国产91精品久久久| 久久精品视频在线| 亚洲第一av网站| 国产精品久久久久久久久免费| 成人av在线天堂| 国产日本欧美在线观看| 欧美成aaa人片免费看| 亚洲欧美国产制服动漫| 亚洲日本欧美日韩高观看| 久久精品99国产精品酒店日本| 国产精品久久久久久久久免费看| 久久精品99国产精品酒店日本| 欧美日韩成人在线观看| 亚洲片国产一区一级在线观看| 国产成人精品a视频一区www| 精品中文字幕久久久久久| 国产一区二区三区在线播放免费观看| 久久久久久久久久久亚洲| 亚洲www在线| 97色伦亚洲国产| 91在线免费视频| 夜夜嗨av一区二区三区四区| 国产欧美久久久久久| 91在线免费观看网站| 亚洲精品美女在线| 日本成熟性欧美| 精品久久久久久中文字幕| 国产经典一区二区| 久久成人在线视频| 91精品在线播放| 久久人人爽亚洲精品天堂| 国产一区二区三区三区在线观看| 欧美日韩国产在线看| 亚洲欧美制服第一页| 欧美性猛交xxxxx水多| 久久久av亚洲男天堂| 亚洲国产古装精品网站| 777777777亚洲妇女| 久久精品人人做人人爽| 91视频-88av| 成人免费网视频| 日韩在线观看你懂的| 久久久精品国产一区二区| 欧美午夜www高清视频| 国产精品久久在线观看| 国产精品网站视频| 日本免费久久高清视频| 国产亚洲欧洲在线| 日韩亚洲国产中文字幕| 欧美大片大片在线播放| 国产丝袜视频一区| 成人一区二区电影| 18性欧美xxxⅹ性满足| 成人精品久久av网站| 日韩电影视频免费| 欧美大奶子在线| 国产精品成人一区二区三区吃奶| 欧美激情一区二区三区成人| 亚洲综合最新在线| 91麻豆国产语对白在线观看| 久久精品国产96久久久香蕉| 精品福利视频导航| 久久精品久久久久久国产 免费| 国产日韩av在线| 日韩欧美在线视频| 国产91在线高潮白浆在线观看| 亚洲自拍偷拍色片视频| 国产91在线视频| 亚洲男人的天堂在线播放| 成人黄色免费看| 国产91精品在线播放| 亚洲日本欧美中文幕| 日韩一区二区欧美| 欧美在线观看视频| 成人av在线网址| 欧美诱惑福利视频| 国产美女久久精品| 一个色综合导航| 国产精品都在这里| 日韩在线视频二区| 国产ts一区二区| 色综合久久88色综合天天看泰| 欧美激情一二三| 日韩av免费在线| 97在线免费视频| 亚洲丝袜在线视频| 国产一区二区三区三区在线观看| 欧美一区二区.| 久久久之久亚州精品露出| 午夜精品久久17c| 伊人av综合网| 中文日韩电影网站| 中文字幕日韩精品在线| 国内精品模特av私拍在线观看| 国产精品一区二区在线| 国产精品久久久久久av福利软件| 国产精品69久久久久| 欧美放荡办公室videos4k| 夜夜躁日日躁狠狠久久88av| 欧美一区二区三区艳史| 成人在线免费观看视视频| 欧美性猛xxx| 日韩av在线一区二区| 国产亚洲精品一区二555| 青青草原成人在线视频| 伊人伊人伊人久久| 国产综合在线观看视频| 午夜精品福利在线观看| 亚洲综合成人婷婷小说| 91中文精品字幕在线视频| 亚洲美女黄色片| 国产美女精彩久久| 国产精品大片wwwwww| 久久精品小视频| 欧美美女18p| 精品无人国产偷自产在线| 欧美最顶级的aⅴ艳星| 一本一本久久a久久精品牛牛影视| 亚洲xxxx做受欧美| 日韩电影视频免费| 欧美日韩国产一区在线| 中文字幕亚洲无线码在线一区| 国产丝袜精品第一页| **欧美日韩vr在线| 欧美丝袜美女中出在线| 国产精品免费福利| 日韩在线免费观看视频| 亚洲自拍小视频| 成人黄色生活片| 精品亚洲一区二区三区四区五区| 日韩精品高清在线| 亚洲欧美日韩国产中文| 久久久亚洲天堂| 国产精品久久婷婷六月丁香| 91九色在线视频| 成人免费大片黄在线播放| 九色成人免费视频| 亚洲永久免费观看| 亚洲午夜av久久乱码| 国产精品视频久久久久| 国产成人精品免费久久久久| 国产精品91在线观看| 亚洲天堂网在线观看| 亚洲精品一区二区久| 欧美精品在线第一页| 日韩国产高清污视频在线观看| 亚洲欧美日韩久久久久久| 欧美中文在线视频| 国产精品福利久久久| 亚洲精品成人久久久| 一本色道久久88亚洲综合88| 欧美国产日韩一区二区在线观看| 欧美成人激情图片网| 久久国产精品影视|