- [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
- [C#] Hướng dẫn viết ứng dụng chat với Gemini AI Google Winform
[C#] Hướng dẫn tính toán (sum, average, count, min, max) trên datatable sử dụng DataTable Compute function và Linq
Bài viết hôm nay, mình sẽ hướng dẫn các bạn tính toán trên DataTable sử dụng Compute Function và Linq trong C# và VB.NET
Ví dụ: Thực hiện tính lương nhân viên trong DataTable như Demo bên dưới
C#
DataTable dt = new DataTable();
dt.Columns.AddRange(new DataColumn[3] { new DataColumn("EmployeeId", typeof(int)),
new DataColumn("Name", typeof(string)),
new DataColumn("Salary", typeof(int)) });
dt.Rows.Add(1, "John Hammond", 45000);
dt.Rows.Add(2, "Mudassar Khan", 32000);
dt.Rows.Add(3, "Robert Schidner", 19000);
dt.Rows.Add(3, "Suzanne Mathews", 18500);
VB.NET
Dim dt As New DataTable()
dt.Columns.AddRange(New DataColumn(2) {New DataColumn("EmployeeId", GetType(Integer)), _
New DataColumn("Name", GetType(String)), _
New DataColumn("Salary", GetType(Integer))})
dt.Rows.Add(1, "John Hammond", 45000)
dt.Rows.Add(2, "Mudassar Khan", 32000)
dt.Rows.Add(3, "Robert Schidner", 19000)
dt.Rows.Add(3, "Suzanne Mathews", 18500)
Bây giờ, mình sẽ thực hiện phép tính trên datatable trên.
Cách 1: Sử dụng Compute function
Cú pháp: DataTable.Compute(hành động, điều kiện)
Hành động: Compute cung cấp cho chúng ta các phương thức tính toán sau: SUM, COUNT, MIN, MAX and AVG.
Điều kiện: Chúng ta sẽ tính toán theo điều kiện.
Câu ví dụ: Tính lương không có điều kiện
C#
int sum = Convert.ToInt32(dt.Compute("SUM(Salary)", string.Empty));
VB.NET
Dim sum As Integer = Convert.ToInt32(dt.Compute("SUM(Salary)", String.Empty))
Tính lương có điều kiện EmployeeID >2
C#
int sum = Convert.ToInt32(dt.Compute("SUM(Salary)", "EmployeeId > 2"));
VB.NET
Dim sum = Convert.ToInt32(dt.Compute("SUM(Salary)", "EmployeeId > 2"))
Cách 2: Sử dụng LINQ
Thực hiện tính tổng lương Employee không có điều kiện
C#
int sum = dt.AsEnumerable().Sum(row => row.Field("Salary"));
VB.NET
Dim sum As Integer = dt.AsEnumerable().Sum(Function(row) row.Field(Of Integer)("Salary")
- Thực hiện tính lương với điều kiện EmployeeID >2
C#
int sum = dt.AsEnumerable().Where(row => row.Field("EmployeeId") > 2).Sum(row => row.Field("Salary"));
VB.NET
Dim sum As Integer = dt.AsEnumerable().Where(Function(row) row.Field(Of Integer)("EmployeeId") > 2).Sum(Function(row) row.Field(Of Integer)("Salary"))
HAVE FUN :)