Bài giảng Lập trình trên Windows: Chương 5.1 - Trần Minh Thái
lượt xem 9
download
Bài giảng Lập trình trên Windows: Chương 5.1 cung cấp cho người học các kiến thức: Các bước lấy dữ liệu, lấy 1 giá trị đơn, lấy tập giá trị, truy vấn tập giá trị và lưu lại,...Mời các bạn cùng tham khảo.
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Bài giảng Lập trình trên Windows: Chương 5.1 - Trần Minh Thái
- Lập trình Windows Chương 5.1. Lấy dữ liệu theo cách Connected 1
- Nội dung • Các bước lấy dữ liệu • Lấy 1 giá trị đơn • Lấy tập giá trị • Truy vấn tập giá trị và lưu lại 2
- Các bước lấy dữ liệu • Bước 1: Chỉ rõ dữ liệu mà ứng dụng cần • Viết yêu cầu bằng câu lệnh SQL • SQL: • Select • DML, DDL, DCL • Bước 2: Gởi yêu cầu đến CSDL • Tạo đối tượng Command • Bước 3: Nhận kết quả 3
- Lấy 1 giá trị đơn • Một số câu lệnh SQL trả về giá trị đơn • Tạo đối tượng Command • Cung cấp câu lệnh SQL cho Command • Thực thi câu lệnh 4
- Lấy 1 giá trị đơn Một số câu lệnh SQL trả về giá trị đơn • Select min(…) From … • Select max(…) From … • Select avg(…) From … • Select count(…) From … • Select sum(…) From … string strSQL = "Select count(*) From TenBang"; 5
- Lấy 1 giá trị đơn Tạo đối tượng Command Đối tượng Command gồm: • Đối tượng Connection • Câu lệnh SQL • Loại câu lệnh: CommadType • Lấy dữ liệu nguyên 1 Bảng: CommadType.TableDirect • Câu lệnh SQL: CommadType.Text • Stored Procedure: CommadType.StoredProcedure 6
- Lấy 1 giá trị đơn Tạo đối tượng Command • Cách 1: SqlCommand cmd = new SqlCommand(); cmd.Connection = conn; cmd.CommandText = strSQL; cmd.CommandType = CommandType.Text; § Cách 2: SqlCommand cmd = new SqlCommand(strSQL); cmd.Connection = conn; cmd.CommandType = CommandType.Text; 7
- Lấy 1 giá trị đơn Tạo đối tượng Command § Cách 3: SqlCommand cmd = new SqlCommand(strSQL, conn); cmd.CommandType = CommandType.Text; § Cách 4: SqlCommand cmd = conn.CreateCommand(); cmd.CommandText = strSQL; cmd.CommandType = CommandType.Text; 8
- Lấy 1 giá trị đơn Thực thi câu lệnh • Phương thức ExecuteScalar() • ExecuteScalar trả về 1 giá trị kiểu object • Dùng ép kiểu để chuyển sang kiểu dữ liệu tương ứng conn.Open(); kq = (Kieu)cmd.ExecuteScalar(); conn.Close(); 9
- Lấy tập giá trị • Câu lệnh SQL trả về tập giá trị • Thực thi câu lệnh • Đối tượng IDataReader • Thuộc tính và phương thức của IDataReader 10
- Lấy tập giá trị Câu lệnh SQL trả về tập giá trị • Tập giá trị: Gồm nhiều dòng hoặc nhiều cột • Select cột1, cột2, … From … string strSQL = "Select cot1, … From TenBang"; 11
- Lấy tập giá trị Thực thi câu lệnh • Phương thức ExecuteReader() trả về 1 đối tượng IDataReader (SqlDataReader hay OleDBDataReader) • IDataReader cho phép duyệt các dòng trong tập dữ liệu !!! Không được đóng kết nối khi còn đang sử dụng đối tượng IDataReader conn.Open(); SqlDataReader reader=cmd.ExecuteReader(); … conn.Close(); 12
- Lấy tập giá trị Đối tượng IDataReader • Đặc điểm của đối tượng IDataReader • Chứa một luồng dữ liệu, tại mỗi thời điểm chỉ truy cập 1 dòng • Read-only • Forward-only 13
- Lấy tập giá trị Thuộc tính và phương thức của IDataReader • Get[DataType](int i): GetInt32(…), GetString(…), … • DataType: phụ thuộc vào kiểu dữ liệu cần lấy • i: là số thứ tự của cột (Ordinal) muốn lấy dữ liệu • string GetName(int i) • Lấy tên cột có số thứ tự i • int GetOrdinal(string name) • Lấy số thứ tự của cột có tên name • bool IsDbNull(int i) • Kiểm tra giá trị cột I có là null/nothing hay không 14
- Lấy tập giá trị Thuộc tính và phương thức của IDataReader • object GetValue(int i) • Lấy giá trị cột i mà không quan tâm kiểu dữ liệu • Hai indexer có chức năng tương tự phương thức GetValue • object dataReader[int i] • object dataReader[string columnName] !!! Nên dùng số thứ tự (i) thay vì tên cột (columnName) 15
- Lấy tập giá trị Thuộc tính và phương thức của IDataReader • bool HasRow • true: cho biết IDataReader chứa 1 hay nhiều dòng dữ liệu • bool Read() • Đọc dòng kế tiếp • Trả về true nếu còn 1 hay nhiều dòng dữ liệu 16
- Lấy tập giá trị Thuộc tính và phương thức của IDataReader conn.Open(); SqlDataReader reader=cmd.ExecuteReader(); if (!reader.HasRows) … while (reader.Read()) { value1 = reader.GetString(0); value2 = reader.GetInt32(1); } conn.Close(); 17
- Truy vấn tập giá trị và lưu lại • Điều kiện lưu dữ liệu vào bộ nhớ • Trong một số trường hợp cần lưu dữ liệu • Data-binding • Cần nhiều thời gian để xử lý dữ liệu Cần lưu dữ liệu lại để xử lý sau 18
- Truy vấn tập giá trị và lưu lại Mỗi dòng là DbDataRecord ArrayList arrList = new ArrayList(); conn.Open(); SqlDataReader reader=cmd.ExecuteReader(); foreach (DbDataRecord rec in reader) { arrList.Add(rec); } conn.Close(); //Sử dụng arrList … 19
- Q&A 20 20
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Lập trình trên Windows: Giới thiệu môn học - Trần Minh Thái
16 p | 142 | 16
-
Bài giảng Lập trình trên Windows: Chương 1 - Trần Minh Thái
68 p | 116 | 16
-
Bài giảng Lập trình trên Windows: Chương 2 - Trần Minh Thái (Phần 1)
141 p | 101 | 15
-
Bài giảng Lập trình trên Windows: Chương 3 - Trần Minh Thái
220 p | 90 | 14
-
Bài giảng Lập trình trên Windows: Chương 2 - Trần Minh Thái (Phần 2)
96 p | 84 | 14
-
Bài giảng Lập trình trên Windows: Chương 4 - Trần Minh Thái
35 p | 100 | 12
-
Bài giảng Lập trình trên Windows: Chương 2 - Trần Minh Thái (Phần 3)
29 p | 73 | 10
-
Bài giảng Lập trình trên Windows: Chương 5 - Trần Minh Thái
38 p | 103 | 10
-
Bài giảng Lập trình trên Windows: Chương 5.2 - Trần Minh Thái
86 p | 91 | 9
-
Bài giảng Lập trình trên Windows: Chương 5.5 - Trần Minh Thái
47 p | 64 | 8
-
Bài giảng Lập trình trên Windows: Chương 5.6 - Trần Minh Thái
44 p | 73 | 8
-
Bài giảng Lập trình trên Windows: Chương 5.3 - Trần Minh Thái
25 p | 70 | 7
-
Bài giảng Lập trình trên Windows: Chương 6 - Trần Minh Thái
27 p | 52 | 7
-
Bài giảng Lập trình trên Windows: Chương 5.4 - Trần Minh Thái
22 p | 66 | 6
-
Bài giảng Lập trình trên môi trường Windows: Phần 1 - Windows control
31 p | 96 | 5
-
Bài giảng Lập trình trên Windows với Microsoft® .NET: Bài 6 - Hồ Hoàn Kiếm
15 p | 75 | 5
-
Bài giảng Lập trình trên Windows với Microsoft® .NET: Bài 1 - Hồ Hoàn Kiếm
19 p | 67 | 4
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn