CÁC ĐỐI TƯỢNG TRUY CẬP DỮ LIỆU - Pdf 62

TT. Visual Basic
Trang 57
Chương

4

CÁC ĐỐI TƯỢNG TRUY CẬP
DỮ LIỆU

Mục tiêu:
Chương này gồm các bài tập nhằm rèn luyện sinh viên cách thức lập
trình cơ sở dữ liệu sử dụng thư viện đối tượng Data Access Objects (DAO).
Đây là cách thức lập trình phổ biến đối với các ứng dụng chạy trên máy đơn.
Học xong chương này, sinh viên phải nắm bắt được các vấn đề sau:
- Sử dụng điều khiển dữ liệu để truy xuất cơ s
ở dữ liệu.
- Sử dụng thư viện đối tượng DAO để lập trình cơ sở dữ liệu.
Kiến thức có liên quan:
- Giáo trình Visual Basic, chương 9.
Tài liệu tham khảo:
Visual Basic 6 Certification Exam Guide - Chapter 5, Page 139 - Dan
Mezick & Scot Hillier - McGraw-Hill - 1998.

http://www.vovisoft.com/VisualBasic/VB6Chapter14.htm
http://www.vovisoft.com/VisualBasic/VB6Chapter15.htm

TT. Visual Basic
I. HƯỚNG DẪN

Bước 3: Trong chương trình này ta làm việc với table Titles của cơ sở dữ liệu
BIBLIO.MDB, để xem và sửa đổi các records. Để ý thuộc tính DefaultType của
Data1 có trị số 2- UseJet, tức là dùng kỹ thuật DAO, thay vì dùng kỹ thuật ODBC.

Hình IV.2: Recordset Type
Trang 58
TT. Visual Basic
Khi ta nhấp chuột lên thuộc tính Recordsource của Data1, rồi nhấp lên tam giác nhỏ
bên phải, một ComboBox sẽ mở ra cho ta thấy danh sách các tables trong cơ sở dữ
liệu, chọn Titles. Để ý thuộc tính RecordsetType của Data1 có trị số là 0 - Table:

Bước 4: Một từ mới mà ta sẽ dùng thường xuyên khi truy cập dữ liệu trong VB6 là
Recordset (bộ records). Recordset là một Set of records, nó có thể chứa một số
records hay không có record nào cả. Một record trong Recordset có thể là một record
lấy từ một Table. Trong trường hợp ấy có thể ta lấy về tất cả records trong table hay
chỉ những records thỏa đúng một điều kiện, thí dụ như ta chỉ muốn lấy các records của
những sách xuất bản trước năm 1990 (Year Published < 1990).
Tạo Form có dạng như sau:

Nhận xét:
9 Ta có thể bấm các nút di chuyển Navigator Buttons để đi đến các record đầu
(first), trước (previous), kế (next) và cuối (last). Mỗi lần ta di chuyển đến một record
mới là chi tiết của record ấy sẽ hiển thị. Nếu không dùng các Navigator Buttons, ta
cũng có thể viết đoạn mã để làm công tác tương đương bằng cách gọi các hàm trên
Recordset là MoveFirst, MovePrevious, MoveNext và MoveLast.
9 Khi record cuối của Recordset đang hiển thị, n
ếu ta gọi hàm MoveLast thì
thuộc tính EOF (End-Of-File) của Recordset trở thành True. Tương tự như vậy, khi
record thứ nhất của Recordset đang hiển thị, nếu ta gọi hàm MovePrevious thì thuộc
tính BOF (Begin-Of-File) của Recordset trở thành True. Nếu một Recordset không có
chứa một record nào cả thì cả hai thuộc tính EOF và BOF đều là True.
9 Khi record đầu tiên đang hiển thị, nếu ta sửa Year Published để đổi từ 1985
thành 1983 rồi nhấp Navigator button Next để hiển thị record thứ
nhì, kế đó click
Navigator button Previous để hiển thị lại record đầu tiên thì ta sẽ thấy là trường Year
Published của record đầu tiên đã thật sự được thay đổi (updated) thành 1983.
Điều nầy có nghĩa rằng khi di chuyển từ record nầy đến record khác thì nếu
record nầy đã có sự thay đổi do người sử dụng, nó lưu trữ sự thay đổi đó trước khi di
chuyển. Chưa chắc là ta muốn điều nầy, do đó, n
ếu ta không muốn người sử dụng tình
cờ sửa đổi một record thì ta có thể đặt thuộc tính Locked của các textboxes ấy thành
True để người sử dụng không thể sửa đổi các textboxes như trong hình dưới đây:

TT. Visual Basic
Trang 61

Hình IV.5: Khóa (lock) Textbox
Bước 10: Lúc chương trình mới khởi động, người sử dụng đang xem thông tin các
records thì hai buttons Update và Cancel không cần phải làm việc. Do đó ta sẽ Lock
(khóa) các textboxes và disable hai buttons nầy vì không cần dùng chúng.
Bước 11: Trong Sub SetControls dưới đây, ta dùng một tham số gọi là Editing với trị
số False hay True tùy theo người dùng đang xem (browse) hay sửa đổi (Edit), ta gọi là
Browse mode và Edit mode. Trong Edit mode, các Textboxes được unlocked (mở
khóa) và các nút cmdNew, cmdDelete và cmdEdit trở nên vô hiệu lực:
Sub SetControls(ByVal Editing As
Boolean)
' Lock/Unlock textboxes
txtTitle.Locked = Not Editing
txtYearPublished.Locked = Not Editing
txtISBN.Locked = Not Editing
txtPublisherID.Locked = Not Editing
' Enable/Disable buttons
CmdUpdate.Enabled = Editing
CmdCancel.Enabled = Editing
CmdDelete.Enabled = Not Editing
cmdNew.Enabled = Not Editing
CmdEdit.Enabled = Not Editing
End Sub

Trong Browse mode, Form có dạng như sau: Hình IV.7: Kết quả thực thi
Bước 12: Thủ tục SetControls được gọi trong Sub Form_Load khi chương trình khởi
động và sự kiện CmdEdit_Click được xử lý như sau:
Private Sub Form_Load()
duongdan = App.Path

MsgBox Err.Description
Exit Sub
End Sub
Bước 14: Ta có thể Update (cập nhật) một record trong Recordset bằng hàm Update.
Nhưng ta chỉ có thể gọi hàm Update của một Recordset khi Recordset đang ở trong
Edit hay AddNew mode. Ta đặt một Recordset vào Edit mode bằng cách gọi hàm
Edit của Recordset, thí dụ như Data1.Recordset.Edit. Tương tự như vậ
y, ta đặt một
Recordset vào AddNew mode bằng cách gọi hàm AddNew của Recordset, thí dụ như
Data1.Recordset.AddNew.
Private Sub cmdNew_Click()
Data1.Recordset.AddNew
SetControls (True)
End Sub

Private Sub cmdUpdate_Click()
Data1.Recordset.Edit
Data1.Recordset.Update
SetControls (False)
End Sub

Bước 15: Lưu dự án và chạy chương trình.

TT. Visual Basic
Bài tập 4-2
CÁC ĐỐI TƯỢNG CƠ BẢN CỦA DAO


DataSource = Data1
Ta được hình dạng của form1 như sau:
Trang 64


Nhờ tải bản gốc

Tài liệu, ebook tham khảo khác

Music ♫

Copyright: Tài liệu đại học © DMCA.com Protection Status