Kỹ thuật phân trang trong trang asp.net - Dùng Store
mweb- Trên website này có viết bài "Kỹ thuật phân trang bằng Store Procedure" nhưng nhiều bạn chưa áp dụng được nó để phân trang trong asp.net và có nhiều bạn hỏi cách làm. Bài này mình sẽ hướng dẫn các bạn sử dụng thuật toán của bài viết đó vào trang asp.net. mweb- ...
mweb- Trên website này có viết bài \"Kỹ thuật phân trang bằng Store Procedure\" nhưng nhiều bạn chưa áp dụng được nó để phân trang trong asp.net và có nhiều bạn hỏi cách làm. Bài này mình sẽ hướng dẫn các bạn sử dụng thuật toán của bài viết đó vào trang asp.net.
mweb- Trên website này có viết bài "Kỹ thuật phân trang bằng Store Procedure" nhưng nhiều bạn chưa áp dụng được nó để phân trang trong asp.net và có nhiều bạn hỏi cách làm. Bài này mình sẽ hướng dẫn các bạn sử dụng thuật toán của bài viết đó vào trang asp.net.
Trong bài viết "Kỹ thuật phân trang bằng Store Procedure" thì dữ liệu hiển thị sẽ được chia làm 2 phần, một phần là dữ liệu truy vấn, một phần là chuỗi html hiển thị phân trang. Vậy để sử dụng nó bạn cần đổ dữ liệu từ Store vào DataSet. Khi đó phần dữ liệu truy vấn sẽ là Table[0] và phần hiển thị phân trang là Table[1]. Vậy bạn cần viết hàm để thực hiện nó. Để thực hiện mình lấy database Northwind, truy vấn dữ liệu từ bảng Customrs. Với Stored Procedure spPhanTrangSQL bạn xem ở bài viết "Kỹ thuật phân trang bằng Store Procedure" còn Store truy vẫn dữ liệu mình viết như sau:
--CREATE BY hungbv.com.vn CREATE PROCEDURE [dbo].[spCustomers_PhanTrang] @currPage int, @recodperpage int, @Pagesize int AS Begin Begin WITH s AS ( SELECT ROW_NUMBER() OVER(ORDER BY CustomerID, CompanyName) AS RowNum, CustomerID, CompanyName, ContactName, City FROM Customers ) Select * From s Where RowNum Between (@currPage - 1)*@recodperpage+1 AND @currPage*@recodperpage END -- Tính tổng số bản ghi DECLARE @Tolal int SELECT @Tolal=Count(*) FROM Customers EXEC spPhanTrangSQL @Tolal, @currPage, @Pagesize, @recodperpage END
Trong trang aspx bạn cần một Gridview và một Literal để hiển thị dữ liệu như sau:
Khi chạy dữ liệu được hiển thị như hình minh họa sau:
Giờ chúng ta sẽ viết Các hàm cần thực hiện hiển thị dữ liệu:
1. Hàm thực thi một Store đổ dữ liệu vào DataSetprivate static DataSet ThucThiStore_DataSet( string StoredProcedure, params SqlParameter[] Parameters) { //Khai báo cuỗi kết nối2. Hàm lấy dữ liệu từ Store trả về một DataSet
string ConnectionString = @"Server =.SQL2005;Initial Catalog=Northwind;User ID=sa;Password=sa"; SqlConnection Conn = new SqlConnection(ConnectionString); SqlCommand Command = new SqlCommand(StoredProcedure, Conn); if (Parameters != null) { Command.Parameters.Clear(); Command.Parameters.AddRange(Parameters); } DataSet ds = new DataSet(); SqlDataAdapter da = new SqlDataAdapter(StoredProcedure, Conn); Command.CommandType = CommandType.StoredProcedure; da.SelectCommand = Command; try { //Mở kết nối
Conn.Open(); da.Fill(ds); } finally
{
// Đóng kết nối
if (Conn.State == ConnectionState.Open)
Conn.Close(); Conn.Dispose(); } return ds;
}
private DataSet StoreToDataSet( int currPage, int recodperpage, int Pagesize) { DataSet dts = new DataSet(); SqlParameter[] arrParam = { new SqlParameter("@currPage", SqlDbType.Int), new SqlParameter("@recodperpage", SqlDbType.Int), new SqlParameter("@Pagesize", SqlDbType.Int) }; arrParam[0].Value = currPage; arrParam[1].Value = recodperpage; arrParam[2].Value = Pagesize; return ThucThiStore_DataSet("spCustomers_PhanTrang", arrParam); }
3. Hàm nạp dữ liệu để hiển thị
private void NapDuLieu(int currPage, int recodperpage, int Pagesize) { DataSet ds = StoreToDataSet(currPage, recodperpage, Pagesize); DataTable dtbData = ds.Tables[0]; DataTable dtbPhanTrang = ds.Tables[1]; if (dtbData.Rows.Count > 0) { GridView1.DataSource = dtbData; GridView1.DataBind(); if (dtbPhanTrang.Rows.Count > 0) { ltlPhanTrang.Text = dtbPhanTrang.Rows[0]["PhanTrang"] + ""; } } }
Trong hàm này bạn thấy dữ liệu được chia làm 2 phần như đã nói ở trên và Phân dữ liệu truy vấn là Table[0] được bind vào Gridview1 còn phần dữ liệu phân trang là Table[1] (Chỉ là 1 bản ghi dữ liệu dang html được gán vào ltlPhanTrang).
Trong hàm Page_Load bạn cần khai báo 1 biến page và hiển thị dữ liệu như sau:
protected void Page_Load(object sender, EventArgs e) { int page = int.Parse("0" + Request.QueryString["page"]); if (page == 0) page = 1; if (!IsPostBack) { NapDuLieu(page, 10, 5); } }
Xem hàm Page_Load bạn thấy mình truyền giá trị 10 là số bản ghi hiển thị cho mỗi trang (rowperpage) và giá trị 5 là số trang hiển thị mỗi phân đoạn (@PageSize)
Bạn có thể download mã nguồn trang asp mình viết về tham khảo tại đây. Tham khảo thêm bài viết vềphân trang trong Gridview
Chúc bạn thành công
Nguồn:http://www.thietkewebsmart.com/asp-net-csharp/ky-thuat-phan-trang-trong-trang-asp-net-dung-store/644.htm
Bình luận