C# Web分頁功能實現

来源:https://www.cnblogs.com/zyp520/archive/2019/11/04/11793418.html
-Advertisement-
Play Games

無論是網站還是APP分頁功能都是必不可少的。為什麼使用分頁呢? 1,載入速度快,不會占用伺服器太多資源,減少伺服器壓力。 2,減少資料庫壓力。 3,提升用戶體驗。 那麼我們常用的分頁方法有兩種。 1,真分頁:每頁都會從資料庫讀取少量數據,優點就是讀取數據量少,性能非常好,大型網站往往採用這種方式。 ...


無論是網站還是APP分頁功能都是必不可少的。為什麼使用分頁呢?

1,載入速度快,不會占用伺服器太多資源,減少伺服器壓力。

2,減少資料庫壓力。

3,提升用戶體驗。

 

那麼我們常用的分頁方法有兩種。

1,真分頁:每頁都會從資料庫讀取少量數據,優點就是讀取數據量少,性能非常好,大型網站往往採用這種方式。

2,假分頁:從資料庫一次性讀取大量數據,但由於數據量比較大,導致響應時間長,但是之後的每一頁都是快速顯示,避免多次訪問資料庫。

我們常用的就是資料庫分頁(真分頁)。下麵看是如何實現的。

 

先定義存儲過程

 

CREATE PROC DataUser
@Page int,
@intPagenum int,
@Total int output
as
DECLARE
@startIndex int,
@endIndex int;
set @startIndex=(@Page-1)*@intPagenum+1;
set @endIndex=@Page*@intPagenum;
begin
 select @Total=COUNT(1) from Blogs_User
 select OpenId,UserName,Href_Img,CONVERT(varchar(20),Addtime,20) as Addtime from (select *,ROW_NUMBER() over(order by Addtime desc) as tableId from Blogs_User) tableuser where tableId>=@startIndex and tableId<=@endIndex
end

 

現在我們封裝執行存儲過程的方法

/// <summary>
/// 執行存儲過程,返回DataTable和總記錄條數
/// </summary>
/// <param name="page">頁碼</param>
/// <param name="intPagenum">每頁數量</param>
/// <returns></returns>
public static JsonDataTable GetUserDataDao(int page, int intPagenum)
{
            try
            {
                DataSet ds = new DataSet();
                JsonDataTable result = new JsonDataTable();
                using (SqlConnection conn = new SqlConnection(Getconnection()))
                {
                    using (SqlCommand cmd = conn.CreateCommand())
                    {
                        cmd.CommandText = "DataUser";//存儲過程名稱
                        cmd.CommandType = CommandType.StoredProcedure;
                        cmd.Parameters.Add(new SqlParameter("@Page", SqlDbType.Int));//入參
                        cmd.Parameters.Add(new SqlParameter("@intPagenum", SqlDbType.Int));//入參
                        cmd.Parameters["@Page"].Value = page;
                        cmd.Parameters["@intPagenum"].Value = intPagenum;
                        SqlParameter parameter = cmd.Parameters.Add("@Total", SqlDbType.Int);
                        parameter.Direction = ParameterDirection.Output;
                        if (conn.State == ConnectionState.Closed)
                        {
                            conn.Open();
                        }
                        SqlDataAdapter my = new SqlDataAdapter(cmd);
                        my.Fill(ds);
                        result.dt = ds.Tables[0];
                        result.Total = Convert.ToInt32(cmd.Parameters["@Total"].Value);
                        conn.Close();
                        return result;
                    }
                }
            }
            catch (Exception e)
            {
                ErrorLog.Write("後臺獲取用戶列表異常", e);
                return null;
            }
}

 

封裝讀取數據介面

[HttpPost]
public JsonResult GetUserList(int page, int intPagenum)
{
            JsonDataTable result = Blogs_UserDao.GetUserDataDao(page, intPagenum);
            if (result != null && result.dt != null && result.dt.Rows.Count > 0)
            {
                result.JsonData = JsonHelper.JsonDataTable(result.dt);
                result.dt = null;
                return BaseJsonResult.GetInstance().CreateJsonGetResult(true, "成功!", result);
            }
            return BaseJsonResult.GetInstance().CreateJsonGetResult(false, "失敗,沒有數據!", null);
}

後臺分頁就已經完成了。

 

前端JS調用,有分頁的UI組件,也可以自己做成“載入更多”分頁方式,使用ajax調用介面非同步載入數據。

//載入更多點擊事件 Dataloading() {
            this.Page++;//當前頁碼
            $.post("/M_BlogsAPI/GetNewShare", { page: this.Page, ShareTypeId: 0, Pagesize: this.Pagesize }, function (data) {
                if (data.Result) {
                    var AddNewShare = JSON.parse(data.Data.NewShareJson);
                    for (var i = 0; i < AddNewShare.length; i++) {
                        app.Blogs_NewShare.push(AddNewShare[i]);
                    }
                }
            });
}

這裡我使用的VUE。先預設Page=1,點擊載入更多時,Page+1,再調用介面讀取當前頁面的數據再迴圈添加到數組裡面。效果看博客留言或者短視頻頁面。

 

本文來自:C# Web分頁功能實現 | 小曾博客


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文源碼: "GitHub·點這裡" || "GitEE·點這裡" "01:項目技術選型簡介,架構圖解說明" "02:業務架構設計,系統分層管理" "03:資料庫選型,業務數據設計規劃" 04:中間件集成,公共服務管理 一、中間件簡介 中間件是基礎軟體的一類, 屬於復用性極高的軟體。處於操作系統軟體 ...
  • 重構是 一種對軟體進行修改的行為,但它並不改變軟體的功能特征,而是通過讓軟體程式更清晰,更簡潔和更條理來改進軟體的質量。代碼重構之於軟體,相當於結構修改之於散文。每次人們對如何對代碼進行重構的討論就像是討論如果對一篇文學作品進行修訂一樣無休無止。所有人都知道應該根據項目的自身情況來對代碼進行重構,而 ...
  • 1. springboot是對spring的缺點進行改善和優化,它的約定大於配置,開箱即用,沒有代碼生成,也不需要xml文件配置,可以修改屬性值來滿足需求 2. springboot的入門程式 在idea中創建springboot的項目 (1) 預設有個DemoApplication類,是sprin ...
  • (手機橫屏看源碼更方便) 註:java源碼分析部分如無特殊說明均基於 java8 版本。 註:線程池源碼部分如無特殊說明均指ThreadPoolExecutor類。 簡介 前面我們一起學習了線程池中普通任務的執行流程,但其實線程池中還有一種任務,叫作未來任務(future task),使用它您可以獲 ...
  • python 命令行參數解析常用到 argparse 包,但是 argparse 包對 bool 值的傳遞可能和你想不太一樣,在傳遞 bool 的時候,命令行中只要出現了就取 True,不管你設置了該參數取 True 還是 False,這個有點反人類,正確的做法是使用 action='store_t... ...
  • toc: true title: 滴滴實時計算發展之路及平臺架構實踐 date: 2019 08 25 tags: Flink 大數據 滴滴的核心業務是一個實時線上服務,因此具有豐富的實時數據和實時計算場景。本文將介紹滴滴實時計算發展之路以及平臺架構實踐。 <! more 實時計算演進 隨著滴滴業務 ...
  • toc: true title: Flink 從 0 到 1 學習 —— Flink Data transformation(轉換) date: 2018 11 04 tags: Flink 大數據 流式計算 前言 在第一篇介紹 Flink 的文章 "《《從0到1學習Flink》—— Apache ...
  • 官網:http://automapper.org/ 文檔:https://automapper.readthedocs.io/en/latest/index.html GitHub:https://github.com/AutoMapper/AutoMapper/blob/master/docs/i ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...