- [C#] Cách Sử Dụng DeviceId trong C# Để Tạo Khóa Cho Ứng Dụng
- [SQLSERVER] Loại bỏ Restricted User trên database MSSQL
- [C#] Hướng dẫn tạo mã QRcode Style trên winform
- [C#] Hướng dẫn sử dụng temp mail service api trên winform
- [C#] Hướng dẫn tạo mã thanh toán VietQR Pay không sử dụng API trên winform
- [C#] Hướng Dẫn Tạo Windows Service Đơn Giản Bằng Topshelf
- [C#] Chia sẻ source code đọc dữ liệu từ Google Sheet trên winform
- [C#] Chia sẻ source code tạo mã QR MOMO đa năng Winform
- [C#] Chia sẻ source code phần mềm lên lịch tự động chạy ứng dụng Scheduler Task Winform
- [Phần mềm] Tải và cài đặt phần mềm Sublime Text 4180 full version
- [C#] Hướng dẫn download file từ Minio Server Winform
- [C#] Hướng dẫn đăng nhập zalo login sử dụng API v4 trên winform
- [SOFTWARE] Phần mềm gởi tin nhắn Zalo Marketing Pro giá rẻ mềm nhất thị trường
- [C#] Việt hóa Text Button trên MessageBox Dialog Winform
- [DEVEXPRESS] Chia sẻ code các tạo report in nhiều hóa đơn trên XtraReport C#
- [POWER AUTOMATE] Hướng dẫn gởi tin nhắn zalo từ file Excel - No code
- [C#] Chia sẻ code lock và unlock user trong domain Window
- [DEVEXPRESS] Vẽ Biểu Đồ Stock Chứng Khoán - Công Cụ Thiết Yếu Cho Nhà Đầu Tư trên Winform
- [C#] Hướng dẫn bảo mật ứng dụng 2FA (Multi-factor Authentication) trên Winform
- [C#] Hướng dẫn convert HTML code sang PDF File trên NetCore 7 Winform
Phân trang dữ liệu cho DataGridView giống như Web
Có khi nào khi lập trình ứng dụng với số lượng dòng dữ liệu quá nhiều dẫn đến mỗi lần muốn show dữ liệu thì mất quá nhiều thời gian để load. Vì lý do đó mà bài viết hôm nay mình sẽ giới thiệu cho các bạn một cách đó là kỹ thuật phân trang dữ liệu giống như các bạn hay thấy trên web.
Cách này thực chất là bạn tính toán xem có bao nhiêu dòng dữ liệu và mõi lần lấy dữ liệu về thì theo số lượng dòng nhất định để giảm thời gian load. Bây giờ mình cùng bắt đầu thực hiện nha:
Đầu tiên các bạn thiết kế form như hình. Form bao gồm DataGridView để hiển thị, Combobox đê chọn trang, NumericUpDown để quy định bao nhiêu dòng trên 1 trang dữ liệu và 1 Label để hiển thị tổng số trang
Chương trình sẽ bao gồm các sự kiện sau
Load += Form1_Load;
nudNumber.ValueChanged+=nudNumber_ValueChanged;
cboPage.SelectedIndexChanged+=cboPage_SelectedIndexChanged;
Các biến sử dụng trong chương trình
int currentPageIndex = 1;
int pageSize = 20;
int pageNumber = 0;
int fistRow, lastRow;
int rows;
SqlConnection conn = new SqlConnection("Chuỗi kết nối");
Sự kiện khi Load form
void Form1_Load(object sender, EventArgs e)
{
string sql = "select count(*) as MaxNumber from ITSVT";//Muc dich de lay ra so dong.
SqlCommand cmd = new SqlCommand(sql, conn);
conn.Open();
rows = Convert.ToInt32(cmd.ExecuteScalar());
pageTotal();
conn.Close();
}
Hàm dùng để tính toán có bao nhiêu trang
void pageTotal()
{
pageNumber = rows % pageSize != 0 ? rows / pageSize + 1 : rows / pageSize; //Tính xem có báo nhiêu trang nếu có pageSize trên trang
lblTotal.Text = " / " + pageNumber.ToString();
cboPage.Items.Clear();
for (int i = 1; i < pageNumber; i++)
cboPage.Items.Add(i + "");
cboPage.SelectedIndex = 0;
}
Tiếp đến là sự kiện khi thay đổi số dòng mặc định trên 1 trang dữ liệu
private void nudNumber_ValueChanged(object sender, EventArgs e)
{
pageSize = Convert.ToInt32(nudNumber.Value);
pageTotal();
}
Và cuối cùng là sự kiện khi ta chọn 1 trang bất kỳ trong tổng số trang
void cboPage_SelectedIndexChanged(object sender, EventArgs e)
{
currentPageIndex = Convert.ToInt32(cboPage.Text);
fistRow = pageSize * (currentPageIndex - 1); //Dòng đầu
lastRow = pageSize * (currentPageIndex);//Dòng cuối cùng của trang được chọn
string sql = "select Row_number() over(order by ITS_REC_VT) STT, MA_VT,TEN_VT,TEN_VT2 from ITSVT"; //Column ITS_REC_VT thường nên chọn là column làm khóa chính
//Có thể dùng Select * hoặc chỉnh định vài column cần thiết để cải thiện tốc độ load dữ liệu. Như vd ở trên của mình là các column: MA_VT,TEN_VT,TEN_VT2
SqlDataAdapter da = new SqlDataAdapter(sql, conn);
DataSet ds = new DataSet();
da.Fill(ds, fistRow, pageSize, "ITSVT"); //Lấy dữ liệu về từ dòng thứ fistRow và lấy pageSize dòng
dataGridView1.DataSource = ds.Tables[0];
}
Và cuối cùng là nhấn F5 để chạy và thưởng thức thành quả.
Nếu bạn chọn 1 trang bất kỳ trong tổng số trang thì chương trình sẽ load về những dữ liệu tương ứng
Chúc các bạn thành công. Có thắc mắc hãy comment lại mình sẽ giải thích và nếu thấy hữu ích hãy like hoặc shared để giới thiệu page của chúng mình trên facebook nhằm tạo động lực để nhóm tụi mình làm nhiều bài hơn để chia sẻ cho các bạn. Cảm ơn!
Link download nếu bạn làm biếng code lại