THIẾT KẾ BIỂU MẪU DÙNG CÁC ĐIỀU KHIỂN - CHỈ ĐỊNH VỊ TRÍ CƠ SỞ DỮ LIỆU - 5
Số trang: 15
Loại file: pdf
Dung lượng: 521.37 KB
Lượt xem: 8
Lượt tải: 0
Xem trước 2 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
Cách chỉ định tên cơ sở dữ liệu trong giai đoạn thiết kế (at design time) ta đã dùng trước đây tuy tiện lợi nhưng hơi nguy hiểm, vì khi ta cài chương trình nầy lên máy tính khác, chưa chắc tập tin cơ sở dữ liệu ấy nằm trong một thư mục có cùng tên. Ví dụ trên máy tính này thì cơ sở dữ liệu nằm trong thư mục E:Program FilesMicrosoft Visual StudioVB98, nhưng trên máy tính khác thì cơ sở dữ liệu nằm trong thư mục D:BasicBt4-1 chẳng hạn. Do đó, khi chương trình khởi động ta...
Nội dung trích xuất từ tài liệu:
THIẾT KẾ BIỂU MẪU DÙNG CÁC ĐIỀU KHIỂN - CHỈ ĐỊNH VỊ TRÍ CƠ SỞ DỮ LIỆU - 5 TT. Visual Basic Hình IV.5: Khóa (lock) TextboxCHỈ ĐỊNH VỊ TRÍ CƠ SỞ DỮ LIỆU LÚC CHẠY CHƯƠNG TRÌNHBước 7: Cách chỉ định tên cơ sở dữ liệu trong giai đoạn thiết kế (at design time) ta đãdùng trước đây tuy tiện lợi nhưng hơi nguy hiểm, vì khi ta cài chương trình nầy lênmáy tính khác, chưa chắc tập tin cơ sở dữ liệu ấy nằm trong một thư mục có cùng tên.Ví dụ trên máy tính này thì cơ sở dữ liệu nằm trong thư mục E:ProgramFilesMicrosoft Visual StudioVB98, nhưng trên máy tính khác thì cơ sở dữ liệu nằmtrong thư mục D:BasicBt4-1 chẳng hạn. Do đó, khi chương trình khởi động ta nênxác định lại vị trí của cơ sở dữ liệu. Chẳng hạn ta muốn để cơ sở dữ liệu trong cùngmột thư mục với chương trình đang chạy, ta có thể dùng thuộc tính Path củaApplication Object App. Khai báo một biến tên duongdan trong phần [General][Declaration] củaForm1: Dim duongdan As StringBước 8: Ta xử lý sự kiện Form_Load như sau: Private Sub Form_Load() duongdan = App.Path If Right(duongdan, 1) Then duongdan = duongdan & Data1.DatabaseName = duongdan & BIBLIO.MDB End SubTHÊM BỚT CÁC RECORDSBước 9: Chương trình đến đây tạm ổn, nhưng nó không cho ta công cụ để thêm (add),bớt (delete) các records. Bây giờ hãy đặt vào Form 5 buttons tên: cmdEdit, cmdNew,cmdDelete, cmdUpdate và cmdCancel. Trang 61 TT. Visual BasicBước 10: Lúc chương trình mới khởi động, người sử dụng đang xem thông tin cácrecords 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 thiBướ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 If Right(duongdan, 1) Then duongdan = duongdan & Data1.DatabaseName = duongdan & BIBLIO.MDB SetControls (False) End Sub Private Sub CmdEdit_Click() Trang 62 TT. Visual Basic SetControls (True) End SubBước 13: Khi ta xóa một record trong recordset, vị trí của record hiện tại (currentrecord) vẫn không thay đổi. Do đó, sau khi xóa một record ta phải MoveNext. Tuynhiên, nếu ta vừa xóa record cuối của Recordset thì sau khi MoveNext, thuộc tínhEOF của Recordset sẽ thành True. Thành ra ta phải kiểm tra điều đó, nếu đúng vậy thìlại phải MoveLast để hiển thị record cuối của Recordset như trong đoạn mã của SubcmdDelete_Click dưới đây: Private Sub CmdDelete_Click() On Error GoTo DeleteErr With Data1.Recordset Xoa record .Delete Nhay den record ke .MoveNext If .EOF Then .MoveLast Exit Sub End With DeleteErr: MsgBox Err.Description Exit Sub End SubBướ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 ở trongEdit hay AddNew mode. Ta đặt một Recordset vào Edit mode bằng cách gọi hàmEdit của Recordset, thí dụ như Data1.Recordset.Edit. Tương tự như vậy, ta đặt mộtRecordset 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 SubBước 15: Lưu dự án và chạy chương trình. Trang 63 ...
Nội dung trích xuất từ tài liệu:
THIẾT KẾ BIỂU MẪU DÙNG CÁC ĐIỀU KHIỂN - CHỈ ĐỊNH VỊ TRÍ CƠ SỞ DỮ LIỆU - 5 TT. Visual Basic Hình IV.5: Khóa (lock) TextboxCHỈ ĐỊNH VỊ TRÍ CƠ SỞ DỮ LIỆU LÚC CHẠY CHƯƠNG TRÌNHBước 7: Cách chỉ định tên cơ sở dữ liệu trong giai đoạn thiết kế (at design time) ta đãdùng trước đây tuy tiện lợi nhưng hơi nguy hiểm, vì khi ta cài chương trình nầy lênmáy tính khác, chưa chắc tập tin cơ sở dữ liệu ấy nằm trong một thư mục có cùng tên.Ví dụ trên máy tính này thì cơ sở dữ liệu nằm trong thư mục E:ProgramFilesMicrosoft Visual StudioVB98, nhưng trên máy tính khác thì cơ sở dữ liệu nằmtrong thư mục D:BasicBt4-1 chẳng hạn. Do đó, khi chương trình khởi động ta nênxác định lại vị trí của cơ sở dữ liệu. Chẳng hạn ta muốn để cơ sở dữ liệu trong cùngmột thư mục với chương trình đang chạy, ta có thể dùng thuộc tính Path củaApplication Object App. Khai báo một biến tên duongdan trong phần [General][Declaration] củaForm1: Dim duongdan As StringBước 8: Ta xử lý sự kiện Form_Load như sau: Private Sub Form_Load() duongdan = App.Path If Right(duongdan, 1) Then duongdan = duongdan & Data1.DatabaseName = duongdan & BIBLIO.MDB End SubTHÊM BỚT CÁC RECORDSBước 9: Chương trình đến đây tạm ổn, nhưng nó không cho ta công cụ để thêm (add),bớt (delete) các records. Bây giờ hãy đặt vào Form 5 buttons tên: cmdEdit, cmdNew,cmdDelete, cmdUpdate và cmdCancel. Trang 61 TT. Visual BasicBước 10: Lúc chương trình mới khởi động, người sử dụng đang xem thông tin cácrecords 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 thiBướ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 If Right(duongdan, 1) Then duongdan = duongdan & Data1.DatabaseName = duongdan & BIBLIO.MDB SetControls (False) End Sub Private Sub CmdEdit_Click() Trang 62 TT. Visual Basic SetControls (True) End SubBước 13: Khi ta xóa một record trong recordset, vị trí của record hiện tại (currentrecord) vẫn không thay đổi. Do đó, sau khi xóa một record ta phải MoveNext. Tuynhiên, nếu ta vừa xóa record cuối của Recordset thì sau khi MoveNext, thuộc tínhEOF của Recordset sẽ thành True. Thành ra ta phải kiểm tra điều đó, nếu đúng vậy thìlại phải MoveLast để hiển thị record cuối của Recordset như trong đoạn mã của SubcmdDelete_Click dưới đây: Private Sub CmdDelete_Click() On Error GoTo DeleteErr With Data1.Recordset Xoa record .Delete Nhay den record ke .MoveNext If .EOF Then .MoveLast Exit Sub End With DeleteErr: MsgBox Err.Description Exit Sub End SubBướ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 ở trongEdit hay AddNew mode. Ta đặt một Recordset vào Edit mode bằng cách gọi hàmEdit của Recordset, thí dụ như Data1.Recordset.Edit. Tương tự như vậy, ta đặt mộtRecordset 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 SubBước 15: Lưu dự án và chạy chương trình. Trang 63 ...
Tìm kiếm theo từ khóa liên quan:
thị trường chứng khoán giáo trình đại học kiến thức lịch sử kinh tế thế giới công nghệ thông tin bài tập trắc nghiệmGợi ý tài liệu liên quan:
-
Giáo trình Thị trường chứng khoán: Phần 1 - PGS.TS. Bùi Kim Yến, TS. Thân Thị Thu Thủy
281 trang 972 34 0 -
Nghiên cứu các nhân tố ảnh hưởng đến ý định đầu tư chứng khoán của sinh viên tại Tp. Hồ Chí Minh
7 trang 570 12 0 -
2 trang 516 13 0
-
Giáo trình phân tích một số loại nghiệp vụ mới trong kinh doanh ngân hàng quản lý ngân quỹ p5
7 trang 470 0 0 -
52 trang 429 1 0
-
Top 10 mẹo 'đơn giản nhưng hữu ích' trong nhiếp ảnh
11 trang 311 0 0 -
293 trang 298 0 0
-
Các yếu tố tác động tới quyết định đầu tư chứng khoán của giới trẻ Việt Nam
7 trang 298 0 0 -
MARKETING VÀ QUÁ TRÌNH KIỂM TRA THỰC HIỆN MARKETING
6 trang 295 0 0 -
74 trang 294 0 0