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

首頁 > 編程 > C# > 正文

C#基于數據庫存儲過程的AJAX分頁實例

2020-01-24 02:10:33
字體:
來源:轉載
供稿:網友

本文實例講述了C#基于數據庫存儲過程的AJAX分頁實現方法。分享給大家供大家參考。具體如下:

首先我們在數據庫(SQL Server)中聲明定義存儲過程

復制代碼 代碼如下:
use sales    --指定數據庫 
 
if(exists(select * from sys.objects where name='proc_location_Paging')) --如果這個proc_location_paging存儲過程存在則刪除 
drop proc proc_location_Paging 
go 
 
create proc proc_location_Paging   --創建存儲過程 

@pageSize int,  --頁大小 
@currentpage int,  --當前頁 
@rowCount int output,  --總行數(傳出參數) 
@pageCount int output  --總頁數(傳出參數) 

as 
begin 
 
select @rowCount= COUNT(locid) from location  --給@rowCount賦值 
 
select @pageCount= CEILING((count(locid)+0.0)/@pageSize) from location  --給@pageCount賦值 
 
select top (@pagesize)* from (select ROW_NUMBER() over(order by locid) as rowID,* from location) as t1 
where rowID >(@pageSize*(@currentpage-1)) 
 
end 
go 
---------------------------------以上就表示這個存儲過程已經定義完了。 
 
---------------------------------以下是執行這個存儲過程。我們可以看結果 
 
declare @rowCount int,@pageCount int  --先聲明兩個參數 
 
--執行proc_location_Paging這個存儲過程。@rowCount,@pageCount后面都有output 表示它們兩是輸出參數 
exec proc_location_Paging 10,1,@rowCount output,@pageCount output   
 
select @rowCount,@pageCount  --查詢這兩個參數的值

因為是直接訪問數據庫的,所以我們將下面這條方法寫入到DAL層中,這里我將它寫入到SqlHelper中

復制代碼 代碼如下:
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Configuration; 
using System.Data.SqlClient; 
using System.Data; 
using System.Reflection; 
 
namespace LLSql.DAL 

    public class SqlHelper 
    { 
        /// <summary> 
        /// 獲取連接數據庫字符串 
        /// </summary> 
        private static string connStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString; 
        public static DataTable ExecuteProcPageList(int pageSize, int currentPage, out int rowCount, out int pageCount) 
        { 
            using (SqlConnection conn = new SqlConnection(connStr)) 
            { 
                conn.Open(); 
                using (SqlCommand cmd = conn.CreateCommand()) 
                { 
                    cmd.CommandText = "proc_location_paging"; //存儲過程的名字 
                    cmd.CommandType = CommandType.StoredProcedure; //設置命令為存儲過程類型(即:指明我們執行的是一個存儲過程)
                    rowCount = 0; 
                    pageCount = 0;//這里隨便給rowCount,pageCount賦個值,因為使用out傳遞參數的時候,在方法內部一定要給out參數賦值才能用它,但是雖然這里給它賦初值了,但是在執行存儲過程中,存儲過程又會給這兩個參數賦值,并返還回來給我們,那個才是我們要值 
                    SqlParameter[] parameters ={ 
                             new SqlParameter("@pageSize",pageSize), 
                             new SqlParameter("@currentpage",currentPage), 
                             new SqlParameter("@rowCount",rowCount), 
                             new SqlParameter("@pageCount",pageCount) 
                    }; 
                    //因為在存儲過程中@rowCount 與@pageCount 是一個輸出參數(output), 而parameters這個數組里,第三,和第四個參數就是要用來替換掉這兩個輸出參數的,所以這里要將parameters這個數組里的這兩個參數設為輸出參數。 
                    parameters[2].Direction = ParameterDirection.Output;
                    parameters[3].Direction = ParameterDirection.Output;
                    cmd.Parameters.AddRange(parameters); //將參數傳遞給我們的cmd命令對象 

                    DataTable dt = new DataTable(); 
                    using (SqlDataAdapter adapter = new SqlDataAdapter(cmd)) 
                    { 
                        adapter.Fill(dt);//到數據庫去執行存儲過程,并將結果填充到dt表中 
                    } 
                    //等存儲過程執行完畢后,存儲過程會把這兩個輸出參數傳遞出來。那么我們在這里來取得這兩個返回參數。 
                    rowCount = Convert.ToInt32(parameters[2].Value); 
                    pageCount = Convert.ToInt32(parameters[3].Value); 
                    return dt; 
                } 
            } 
        } 
    } 
}

在DAL文件夾中( 層中) 創建一個Aticel.cs類  產生一個list

復制代碼 代碼如下:
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using System.Data; 
using LLSql.DAL; 
using WebApplication1.Model; 

namespace WebApplication1.DAL 

    public class Aticel 
    { 
        public static List<Location> GetPageListByPageIndex(int pageSize,int currentpage,out int rowCount,out int pageCount) 
        { 
            DataTable dt= SqlHelper.ExecuteProcPageList(pageSize, currentpage,out rowCount,out pageCount); 
            var list = new List<Location>();// 聲明一個泛型對象list 
            if (dt != null && dt.Rows.Count > 0) 
            { 
                //將DataTable轉換成一個list 
                list = (from p in dt.AsEnumerable()  //(遍歷DataTable)
                        select new Model.Location 
                        { 
                            Locid = p.Field<int>("locid"),   //將DateTable里的字段賦值給Location類中的屬性 
                            LocName = p.Field<string>("locName"), 
                            ParentId = p.Field<int>("parentId"), 
                            LocType = p.Field<short>("locType"), 
                            ElongCode = p.Field<string>("elongCode"), 
                            CityCode = p.Field<string>("CityCode"), 
                            BaiduPos = p.Field<string>("BaiduPos"), 
                            Versions = p.Field<short>("Version") 
                        }).ToList();  
            } 
            return list; //將這個list返回回去 
        } 
    } 
}

在API這個文件夾中創建一個GetPageData.ashx 頁 (BLL層) 在這里調用ADL層里的 Aticel.cs類中的GetPageListByPageIndex()方法,獲取一個list  并將這個list轉換成一個Json格式字符串, 共AJAX 異步請求得到。

復制代碼 代碼如下:
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using System.Web.Script.Serialization; 
 
namespace WebApplication1.API 

    /// <summary> 
    /// GetPageData 的摘要說明 
    /// </summary> 
    public class GetPageData : IHttpHandler 
    { 
        /// <summary> 
        /// 根據用戶傳遞的當前頁的頁碼來獲取數據 
        /// </summary> 
        /// <param name="context"></param> 
        public void ProcessRequest(HttpContext context) 
        { 
            context.Response.ContentType = "text/plain"; 
            int pageSize = 10; //設定頁大小,每頁顯示10條數據 
            int currentPage = Convert.ToInt32(context.Request.QueryString["currentPage"]); //設定當前頁 
            int rowCount = 0;  //作為out參數傳遞給方法,在方法里給rowCount賦值 
            int pageCount = 0; //作為out參數傳遞給方法,在方法里給rowCount賦值 
            string jsonData = null;  
            List<Model.Location> list= DAL.Aticel.GetPageListByPageIndex(pageSize, currentPage, out rowCount, out pageCount); 
            if (list != null && list.Count > 0) 
            { 
                //創建Json序列化器,將對象轉換成一個Json格式的字符串 
                JavaScriptSerializer jsz = new JavaScriptSerializer(); 
                jsonData = jsz.Serialize(list); //將一個list對象轉換成json格式的字符串 
                context.Response.Write(jsonData); 
            } 
            else 
            { 
                context.Response.Write("no"); 
            } 
        } 
        public bool IsReusable 
        { 
            get 
            { 
                return false; 
            } 
        } 
    } 
}

前端頁面  (將AJAX請求得到的數據展示也頁面)

復制代碼 代碼如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1" %> 
<!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>使用AJAX分頁</title> 
    <script src="jquery-1.11.2.js" type="text/javascript"></script> 
    <style type="text/css"> 
      table{ margin:80px 500px; } 
      td{ width:50px; height:auto} 
    </style> 
    <script type="text/javascript"> 
        $(function () { 
            $.get("API/GetPageData.ashx?currentPage=2", function (obj) { //假設當前頁是第二頁currentPage=2 
                //debugger; 
 
                var JsonData = $.parseJSON(obj); 
                //alert(JsonData[0].Locid); 
                //debugger; 
                for (var i = 0; i < JsonData.length; i++) { 
                    var data = "<tr><td >" + JsonData[i].Locid + "</td><td >" + JsonData[i].LocName + "</td><td >" + JsonData[i].ParentId + "</td><td >" + JsonData[i].LocType + "</td><td >" + JsonData[i].ElongCode + "</td><td >" + JsonData[i].CityCode + "</td><td >" + JsonData[i].BaiduPos + "</td><td >" + JsonData[i].Versions + "</td></tr>"; 
                    $("#t1").append(data); 
                } 
            }) 
        }) 
    </script> 
</head> 
<body> 
 <table border="1" cellpadding="5" cellspacing="0" style="margin-top:100px;width:600px;" id="t1"> 
    <tr><td>編號</td><td >城市名</td><td >父ID</td><td >locType</td><td >elongCode</td><td >CityCode</td><td >BaiduPos</td><td >Version</td></tr> 
 </table> 
 </body> 
</html>

希望本文所述對大家的C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一色中文字幕| 久久亚洲春色中文字幕| 久久久久久com| 这里只有精品久久| 国产精品第100页| xvideos成人免费中文版| 最近2019中文字幕mv免费看| 国产精品r级在线| 亚洲精品日韩欧美| 国产精品草莓在线免费观看| 国产精品一区二区三区毛片淫片| 国产成人精品综合久久久| 国产精品久久久91| 亚洲激情久久久| 国产精品久久久久久av福利| 欧美激情视频网站| 色综合色综合网色综合| 日韩大片免费观看视频播放| 欧日韩不卡在线视频| 在线亚洲午夜片av大片| 亚洲欧美日韩一区二区三区在线| 日韩欧美中文字幕在线观看| 91精品国产免费久久久久久| 国产精品久久婷婷六月丁香| 色综合男人天堂| 欧美日韩aaaa| 亚洲国产精品一区二区三区| 日韩精品www| www.久久撸.com| 国产91色在线|| 久久久久这里只有精品| 在线播放国产一区二区三区| 91精品国产乱码久久久久久久久| 91国内揄拍国内精品对白| 日韩av一区在线| 欧美性猛交xxxx黑人| 精品久久久香蕉免费精品视频| 欧美激情亚洲一区| 国产成人中文字幕| 欧美亚洲一区在线| 亚洲成人精品久久久| 日韩欧美精品网址| 亚洲欧美日韩国产中文专区| 日韩国产精品一区| 欧美在线视频免费观看| 欧美一级大胆视频| 欧美重口另类videos人妖| 色婷婷亚洲mv天堂mv在影片| 亚洲精品久久久久| 97香蕉久久夜色精品国产| 这里只有精品在线播放| 狠狠色噜噜狠狠狠狠97| 欧美性一区二区三区| 亚洲男子天堂网| 日韩成人久久久| 久久精品久久久久久| 国产精品视频永久免费播放| 国产精品免费在线免费| 欧美一级片在线播放| 成人激情视频在线观看| 欧美激情在线一区| 欧美有码在线观看视频| 国产亚洲欧美日韩美女| 国内精品久久影院| 伊人成人开心激情综合网| 在线观看国产成人av片| 欧美成人四级hd版| 亚洲国产成人av在线| 91亚洲va在线va天堂va国| 亚洲最大的成人网| 青草成人免费视频| 久久国产精品久久国产精品| 欧美一乱一性一交一视频| 久久91亚洲精品中文字幕奶水| 日韩va亚洲va欧洲va国产| 美女啪啪无遮挡免费久久网站| 美女999久久久精品视频| 97婷婷大伊香蕉精品视频| 日韩精品极品在线观看| 精品动漫一区二区三区| 国产日韩欧美中文| 国产精品ⅴa在线观看h| 欧美中文字幕视频| 久久免费视频观看| 亚洲国产精品悠悠久久琪琪| 亚洲第一区第二区| 91亚洲精品在线观看| 国产在线高清精品| 欧美亚洲激情在线| 久久精品国产亚洲7777| xvideos亚洲人网站| 精品久久久久久久中文字幕| 久久99精品久久久久久噜噜| 国产精品黄色av| 国产成人福利网站| 亚洲成年网站在线观看| 国产在线精品一区免费香蕉| 日韩av色综合| 亚洲精品一区在线观看香蕉| 欧美日韩激情视频8区| 亚洲第五色综合网| 国产成人涩涩涩视频在线观看| 美女啪啪无遮挡免费久久网站| 亚洲精品视频播放| 久久久久久久久久久亚洲| 在线日韩日本国产亚洲| 最新国产精品拍自在线播放| 九九热精品在线| 国产精品久久久av久久久| 欧美性猛交视频| 亚洲激情视频网站| 国产成人一区二区三区电影| 久久综合网hezyo| 国产一区二区香蕉| 亚洲午夜精品视频| 国产成人免费91av在线| 久久久久成人精品| 亚洲国产精品成人va在线观看| 136fldh精品导航福利| 青青青国产精品一区二区| 亚洲天堂av在线播放| 久久全国免费视频| 91久久久久久久久久久久久| 亚洲美女av在线| 亚洲国产高清自拍| 国产精品av在线播放| 日本亚洲欧洲色| 国产精品高潮视频| 91欧美激情另类亚洲| 国产亚洲欧洲在线| 91精品在线看| 精品久久久久久中文字幕大豆网| 亚洲女人天堂av| 亚洲美女免费精品视频在线观看| 欧美性猛交xxxx富婆弯腰| 热re99久久精品国产66热| 国产精品久久9| 亚洲男人的天堂在线| 国产精品日韩在线播放| 欧美性猛交xxxx乱大交3| www国产亚洲精品久久网站| 欧美久久久精品| 日韩成人av一区| 91免费版网站入口| 国产午夜一区二区| 777国产偷窥盗摄精品视频| 亚洲一区二区三区视频播放| 日韩精品视频在线免费观看| 在线电影欧美日韩一区二区私密| 国产va免费精品高清在线观看| 亚洲a在线观看| 日韩中文在线中文网三级| 91美女片黄在线观看游戏| 欧美国产精品日韩| 国产精品影院在线观看| 久久中文精品视频| 精品欧美国产一区二区三区| 欧美噜噜久久久xxx| 欧美视频在线看| 亚洲精品久久久久久下一站| 欧美极品少妇xxxxⅹ裸体艺术| 亚洲欧美另类在线观看| 日韩av一区在线观看| 色综合视频一区中文字幕|