Đề tài Báo cáo quản lý điểm sinh viên

Lời giới thiệu 3

Chương 1: Tìm hiểu bài toán 5

1.1. Bài toán quản lý. 6

1.1.1. Quản lý và ứng dụng tin học trong quản lý. 6

1.1.1.1. Một số khái niệm về quản lý 6

1.1.1.2. Ứng dụng tin học trong công tác quản lý 6

1.1.2. Nguyên tắc xây dựng mô hình thông tin quản lý 9

1.1.2.1. Nhu cầu tin học hóa thông tin quản lý 9

1.1.2.2. Phương án xây dựng mô hình thông tin 10

1.2. Khảo sát hệ thống 12

1.2.1. Tổng quan về hệ thống quản lý. 12

1.2.2. Chức năng và nhiệm vụ của hệ thống quản lý điểm sinh viên. 12

1.2.3. Yêu cầu của hệ thống và những khó khăn 12

1.2.4. Những yêu cầu đặt ra đối với hệ thống mới. 13

1.3. Mục đích của đề tài 13

1.4. Yêu cầu phạm vi của đề tài 14

1.4.1. Quản lý hồ sơ sinh viên: 14

1.4.2. Quản lý điểm: 14

Chương 2: Phân tích, thiết kế hệ thống và tổ chức cơ sở dữ liệu. 17

2.1. Mục đích của việc phân tích và thiết kế hệ thống 18

2.1.1. Mục đích: 18

2.1.2. Sơ đồ luồng dữ liệu: 18

2.1.3. Các tính chất của hệ thống 20

2.1.4. Các chức năng cơ bản của hệ thống: 21

2.2. Thiết kế tổng thể chương trình. 24

2.2.1. Biểu đồ luồng dữ liệu mức khung cảnh tổng quát: 24

2.2.2. Sơ đồ phân rã chức năng tổng quát 25

2.2.3. Chức năng cập nhật hồ sơ 26

2.2.4. Chức năng tra cứu 27

2.2.5. Chức năng in bảng điểm 27

2.2.6. Chức năng tổng kết 28

2.2.7. Sơ đồ thuật toán: 29

2.3. Tổ chức hệ thống cơ sở dữ liệu 33

2.3.1. Mô hình thực thể liên kết thực thể. 33

2.3.2. Thiết kế file cơ sở dữ liệu. 34

Chương 3:Tìm hiểu ngôn ngữ đề tài 36

3.1. Cơ sở dữ liệu 37

3.1.1. Khái niệm cơ bản về cơ sở dữ liệu. 37

3.1.2. Các mục tiêu thiết kế cơ sở dữ liệu: 38

3.1.3. Tiến trình thiết kế cơ sở dữ liệu. 38

3.2. Ngôn ngữ phát triển chương trình Visual Basic 6.0 40

3.2.1. Microsoft Visual Basic và các phiên bản 40

3.3.2. Tổ chức của Mirosoft Visual Basic 40

3.2.3. Lập trình trên Mirosoft Visual Basic có thể khái quát như sau. 41

3.2.4. Lập trình trên Mirosoft Visual Basic 41

3.2.5. Visual Basic và Microsoft Access. 42

3.2.6. Mối liên hệ giữa Access và Visual Basic. 43

Chương 4: Các Form trong chương trình 46

1. Form chính của chương trình 47

2. Form Danh mục lớp học 48

3. Danh mục môn học 48

4. Danh mục Sinh viên 49

5. Bảng điểm 49

Mã nguồn chương trình 50

Tài liệu tham khảo 88

 

doc88 trang | Chia sẻ: huong.duong | Lượt xem: 1517 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Đề tài Báo cáo quản lý điểm sinh viên, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
n MSLop Text 5 Mã số lớp học HoTenCha Text 30 Họ tên cha NgheNghiepCha Text 50 Nghề nghiệp của cha HoTenMe Text 30 Họ tên mẹ NgheNghiepMe Text 50 Nghề nghiệp của mẹ Bảng BangDiem lưu trữ thông tin về điểm của sinh viên Tên trường Kiểu dữ liệu Độ rộng Giải thích MSSV Text 10 Mã số sinh viên MSMon Text 10 Mã số môn học Diem1 Single Điểm thi lần 1 Diem2 Single Điểm thi lần 2 DiemTK Single Điểm tổng kết Bảng LopHoc lưu trữ danh mục lớp học Tên trường Kiểu dữ liệu Độ rộng Giải thích MSLop Text 5 Mã số lớp học (Primary key) TenLop Text 30 Tên lớp học KhoaHoc Number Integer Khoá học Bảng MonHoc lưu trữ danh mục môn học Tên trường Kiểu dữ liệu Độ rộng Giải thích MSMon Text 5 Mã số môn (Primary key) TenMon Text 30 Tên môn HocKy Number Integer Học kỳ SoTrinh Number Integer Số trình Chương 3 Tìm hiểu ngôn ngữ đề tài Trước khi đi vào phân tích thiết kế bài toán chúng tôi sẽ giới thiệu sơ qua các khái niệm về CSDL và ngôn ngữ phát triển chương trình Visual Basic 6.0 3.1. Cơ sở dữ liệu 3.1.1. Khái niệm cơ bản về cơ sở dữ liệu. Cơ sở dữ liệu là tập hợp các dữ liệu có mối quan hệ với nhau được lưu trữ trong máy theo qui định nào đó . Phần chương trình có thể xử lí, thay đổi dữ liệu gọi là hệ quản trị cơ sở dữ liệu. Theo nghĩa này Hệ quản trị cơ sở dữ liệu có nhiệm vụ rất quan trọng như là một bộ diễn dịch với ngôn ngữ bậc cao nhằm giúp người sử dụng có thể dùng được hệ thống mà ít nhiều không cần quan tâm đến thuật toán chi tiết hoặc biểu diễn dữ liệu trong máy. * Định nghĩa quan hệ: Gọi R = {A1,...,An} là tập hợp hữu hạn của các thuộc tính , mỗi thuộc tính Ai với i=1,...,n có miền giá trị tương ứng là dom (Ai ). Quan hệ trên tập thuộc tính R = {A1,...,An} là tập con của tích Đề - Các r Í dom (A1) x...x dom (An) Miền (domain): là một tập các giá trị .Ví dụ : tập các số nguyên, tập hai số. Mỗi hàng của quan hệ gọi là bộ (tuples). Các cột của quan hệ gọi là các thuộc tính (attributes). Định nghĩa khoá (Key): Khoá của quan hệ r trên tập thuộc tính R = {A1,...,An}là tập con K Í R sao cho bất kỳ hai bộ khác nhau t1, t2 ẻ r luôn thoả t1(K) ạ t2(K), bất kỳ tập hợp con thực sự K* è K nào đó đều không có tính chất đó. Tập hợp K là các siêu khoá (superkey) của quan hệ r nếu K là một khoá của quan hệ r. 3.1.2. Các mục tiêu thiết kế cơ sở dữ liệu: Chiến lược của việc thiết kế cơ sở dữ liệu là hoàn thành các mục tiêu sau đây: - Đáp ứng các nhu cầu về thông tin của bạn hoặc của tổ chức một cách kịp thời, nhất quán về kinh tế. - Loại bỏ hoặc giảm thiểu khả năng trùng lặp nội dung cơ sở dữ liệu trong tổ chức. - Cho phép nhanh chóng truy cập các thành phần thông tin cụ thể trong cơ sở dữ liệu mà từng phạm trù người dùng yêu cầu. - Chừa chỗ cho phần mở rộng cơ sở dữ liệu để thích ứng với các nhu cầu của một tổ chức đang tăng trưởng, như bổ sung các qui trình và sản phẩm mới, tuân theo các yêu cầu báo cáo của chính quyền, và liên hợp các ứng dụng mới về hỗ trợ ra quyết định và xử lí giao dịch. - Duy trì tính nguyên vẹn của cơ sở dữ liệu để nó chỉ chứa các thông tin đã được hợp lệ hoá, kiểm toán được. - Ngăn cản những người lạ truy cập cơ sở dữ liệu. - Chỉ cho phép truy cập những thành phần thông tin cơ sở dữ liệu mà từng người hay phạm trù riêng lẻ cần đến trong quá trình công việc. Có thể cho phép hoặc từ chối người dùng xem dữ liệu trong các bảng cụ thể của cơ sở dữ liệu. - Chỉ cho phép những người có quyền mới được bổ sung hay hiệu chỉnh thông tin trong cơ sở dữ liệu. - Dễ dàng tạo các ứng dụng nhập liệu, hiệu chỉnh, hiển thị và báo cáo, phục vụ hiệu quả các nhu cầu của người dùng cơ sở dữ liệu. 3.1.3. Tiến trình thiết kế cơ sở dữ liệu. Tiến trình thiết kế một cơ sở dữ liệu quan hệ bao gồm các bước sau: Định danh các đối tượng ( nguồn dữ liệu) mà hệ cơ sở dữ liệu sẽ hiển thị. - Phát hiện các phần kết hợp giữa các đối tượng ( Khi có nhiều đối tượng). - Xác định các tính chất quan trọng và các kiểu ứng xử của các đối tượng. - Xây dựng một từ điển dữ liệu mở đầu để định nghĩa các bảng tạo nên cơ sở dữ liệu. - Chỉ định các mối quan hệ giữa các bảng cơ sở dữ liệu dựa trên các phần kết hợp các đối tượng dữ liệu chứa trong bảng và liên hợp thông tin này trong từ điển dữ liệu. - Thiết lập các kiểu cập nhật và giao dịch tạo và sửa đổi dữ liệu trong các bảng, kể cả những yêu cầu cấp cần thiết về tính nguyên vẹn dữ liệu. - Xác định cách dùng các chỉ mục để tăng tốc các tác vụ bộ hỏi mà không làm chậm quá đáng việc bổ sung dữ liệu vào các bảng hoặc tốn quá nhiều dung lượng đĩa. - Quyết định người có quyền truy cập và sửa đổi dữ liệu trong từng bảng (tính bảo mật dữ liệu), và nếu cần, thay đổi cấu trúc các bảng để đảm bảo mật dữ liệu. Sưu liệu thiết kế của cơ sở dữ liệu như một toàn thể; hoàn tất các từ điển dữ liệu cho cơ sở dữ liệu như một toàn thể và từng bảng mà nó chứa; viết các thủ tục để bảo trì cơ sở dữ liệu, kể cả khả năng phục hồi và lưu dự phòng tập tin. 3.2. Ngôn ngữ phát triển chương trình Visual Basic 6.0 3.2.1. Microsoft Visual Basic và các phiên bản Microsoft Visual Basic là một ngôn ngữ lập trình được hãng Microsoft phát triển .Visual Basic gắn liền với khái niệm lập trình trực quan, nghĩa là khi thiết kế chương trình bạn nhìn ngay thấy ngay kết quả qua từng thao tác và giao diện khi chương trình thực hiện. Đây là thuận lợi lớn so với ngôn ngữ lập trình khác, Visual Basic cho phép bạn chỉnh sửa đơn giản, nhanh chóng màu sắc, kích thước, hình dáng của các đối tượng có mặt trong ứng dụng. Về mặt công nghệ lập trình cũng như tổ chức môi trường làm việc, phiên bản 5.0 và 6.0 có nhiều ưu điểm hơn. Mặt khác, phiên bản 5.0 32 bit và 6.0 được phép xây dựng các ứng dụng 32 bit với môi trường làm việc là Microsoft Windows 95 -> 2000. Cụ thể: - Version 5.0: Phiên bản 32 bit, phiên bản tương thích hoàn toàn trên môi trường Windows. Hệ thống thư viện sử dụng các DLL ( Dynamic Link Library ) và các thư viện OLE theo công nghệ OCX. Phiên bản 32 tỏ ra thực sự có ưu điểm trong môi trường Windows 95 & 97 nếu cấu hình máy tính của người sử dụng được các nhu cầu sử dụng cao. - Version 6.0: Là phiên bản mới hiện nay chạy trên môi trường Windows 9.X. Hệ thống sử dụng thư viện DLL và các thư viện OLE theo công nghệ OCX, nhu cầu đòi hỏi cấu hình của máy tính phải đủ mạnh ( máy tính từ 586 trở lên ). 3.3.2. Tổ chức của Mirosoft Visual Basic - Project: Là sản phẩm lập trình trong môi trường Microsoft được tổ chức thành một Project bao gồm: - MDI form: Một Project có thể có một màn hình làm theo chế độ Multi Document Interfaccce. Form: Các màn hình làm việc của Project. Form: Các màn hình làm việc của Project. - Module: Được sử dụng để khai báo các Sub, Function, Type, Constant tổng quát trong Proect. Class Module: khai báo đối tượng trong Project. Controls: Các đối tượng được sử dụng trong form Prọect là các thư viện kiểu VBX hoặc OCX. Mỗi đối tượng được đặc trưng Properties và các Events. Các đối tượng của Microsoft Visual Basic có thể phân chia thành các nhóm sau: Các control chuẩn của hệ điều hành Windows. - Các đối tượng do Microsoft cung cấp (Data control, Rich Text Control...). Các đối tượng do hãng phần mền thứ ba hỗ trợ. 3.2.3. Lập trình trên Mirosoft Visual Basic có thể khái quát như sau. Xây dựng Project trên cơ sở phân tích hệ thống bài toán. Thiết kế các đối tượng. - Điều khiển tính chất các đối tượng và viết mã lệnh xử lí trên các sự kiện và các đối tượng. 3.2.4. Lập trình trên Mirosoft Visual Basic Mirosoft Visual Basic hỗ trợ sử dụng Query trong chương trình của mình. Do vậy việc xử lí dữ liệu có nhiều thuận lợi, đặc biệt CSDL của Access. Trong khi viết chương trình có một số vấn đề quan trọng cần chú ý đó là lỗi và xử lí lỗi. Công cụ gỡ rối: Khi chạy thử chương trình có thể sử dụng công cụ gỡ rối khá mạnh của Mirosoft Visual Basic ( Debug ). Công cụ này cho phép hiệu chỉnh phần câu lệnh ngay trong khi thực hiện chương tình đối với các lôĩ không quan trọng. Để thiết kế cơ sở dữ liệu có thể sử dụng một trong các công cụ sau: ư. Sử dụng phiên bản Micosofft Access tương ứng với phiên bản của Mirosoft Visual Basis. ư. Sử dụng chương trình DataManager được cung cấp kèm theo Visual Basic - Thiết kế báo cáo: Để thiết kế mẫu biểu báo cáo có thể sử dụng một trong các công cụ sau: - Sử dụng phiên bản DataEnviroment tương ứng trong Microsoft Visual Basic Sử dụng DataReport được cung cấp kèm theo. 3.2.5. Visual Basic và Microsoft Access. Visual Basic là ngôn ngữ lập trình hướng sự kiện có thể giải quyết được mọi bài toán. Visual Basic cũng giải quyết đựơc các bài toán quản lí mà các ngôn ngữ khác không có. Để phát huy hết khả năng Visual Basic hay Acces chúng ta phải hiểu thật rõ cơ chế xử lí dữ liệu ( Jet Engine ), Jet Engine cho phép làm việc với nhiều dang thức dữ liệu khác nhau và cung cấp giao diện lập trình hướng đối tượng để làm viêc với CSDL. JetEngin là thành phần cốt lõi của hệ quản trị CSDL Access do đó có thể trở thành một nhà lập trình chuyên nghiệp với Visual Basis thì điều đầu tiên là Jet Engine. Tuy nhiên mỗi ngôn ngữ lập trình có một hệ thống mạnh riêng của nó, ở lĩnh vực này nó không đáp ứng được, không thích hợp được nhưng ở lĩnh vực khác thì lại làm được. Ví dụ như Access có công cụ thiết kế báo biểu mạnh hơn nhiều so với Visual Basis, trong Visual Basic có bộ thiết kế báo biểu không do Microsoft phát triển mà lại do hãng Seagate, và được đưa vào như một OLE Custom Control độc lập. Vì vậy tuỳ theo yêu cầu của một bài toán cụ thể mà người lập trình chọn một ngôn ngữ thích hợp để giải quyết chúng. Visual Basic 6.0 cho phép người lập trình nhúng các đối tượng hay sử dụng các hàm thư viện DLL một các dễ dàng. Visual Basis 2.0 đã nhanh hơn, mạnh hơn và còn sử dụng hơn Visual Basic 1.0. Visual Basic 3.0 tăng thêm những cách thức đơn giản để điều khiển các cơ sở dữ liệu mạnh nhất sẵn có. Visual Basic 4.0 hỗ trợ sự phát triển 32 - bit và bắt đầu tiến trình chuyển Visual Basic thành một ngôn ngữ lập trình hướng đối tượng đầy đủ. Phiên bản 5.0 và 6.0 có nhiều tính năng mạnh hơn, đặc biệt là tốc độ gia tăng đáng kể (khoảng 20% nhanh hơn so với Visual Basic 4.0) và những đặc tính liên quan đến Web. Có 3 khía cạnh khẳng định Visual Basic 6.0 thực sự là một ngôn ngữ lập trình đa năng: Thời gian nhập biểu (Form) và điều khiển (control) nhanh hơn hẳn Visual Basic 4.0 tốc độ truy cập dữ liệu nhanh, công nghệ tối ưu của Mirosoft Visual C++ được dùng trong Visual Basic 5.0 và 6.0, phiên bản Visual Basic 6.0 có thêm một số tính năng ngôn ngữ mong muốn, tăng cường cho Internet và các tính năng cơ sở dữ liệu mạnh hơn. Ngoài ra Visual Basic 5.0 và 6.0 còn có công cụ trợ giúp thông minh, công cụ gỡ rối cao, các công cụ tạo lập ActiveX, cho phép truy cập nhiều nguồn dữ liệu khác nhau. Visual Basic chuyển ứng dụng sang môi trường Web được thực hiện dễ dàng và nhanh chóng hơn. 3.2.6. Mối liên hệ giữa Access và Visual Basic. Microsoft hiện đang làm chủ các hệ Quản trị CSDL: Foxpro, Access, SQL Server. Access do Microsoft phát triển từ đầu và trở thành một trong những sản phẩm thành công nhất. Visual Basic dùng kết nối database engine của Access để xử lí dữ liệu, Visual Basic không phải là một hệ quản trị dữ liệu mà là một ngôn ngữ vạn năng. Với Visual Basic ta có thể phát triển nhiều ứng dụng khác nhau. Nó bao gồm cả trình biên dịch, cho phép nhà phát triển sinh ra các tập tin .EXE chạy độc lập ( dĩ nhiễn cần có thêm các thư viện DLL, VBX, OCX ) còn Access hoàn toàn là một hệ quản trị CSDL. Access không có trình biên dịch như Visual Basic. Tuy nhiên Microsoft cung cấp thêm bộ Access Run time để chạy các ứng dụng mà không cần cài đặt Access. Cách thiết kế trực quan và cách lập trình hướng sự kiện được áp dụng trong Access và Visual Basic. Access tỏ ra mạnh hơn khi cho phép quản lí các sự kiện tinh tế hơn chẳng hạn như Text Box control, Access cho phép xử lí các cự kiện liên quan đến sự thay đổi dữ liệu: OnChange, BeforeUpdate, AfterUpdate trong khi Visual Basic 4.0 chỉ có thể kiểm tra sự kiện Change. Vì vậy Access cho phép phát triển các chương trình cập nhật dữ liệu thông minh hơn do kiểm soát được dữ liệu nhập một cách tinh tế. Ban đầu Access đơn giản chỉ là quản trị CSDL quan hệ ( Relation Database Management System ) dùng trong văn phòng ( nằm trong bộ Microsft Professional Word, Exccel, Power Point ) do đó Microsft đặc biệt chú trọng đến người sử dụng cuối (end user) hơn là nhà phát triển. Điều này làm cho công cụ hỗ trợ thiết kế ( giao diện thiết kế, các Wizard cho phép tự động hoá các quá trình thủ công trong quá trình thiết kế form, table, query ) của Access tỏ ra rất mạnh, hơn hẳn Visual Basic. Chẳng hạn nhiều lập trình viên kinh nghiệm khi viết các câu lệnh SQL trong Visual Basic thường dùng kềm bộ thiết kế Query trong Access để sinh ra trong câu lệnh SQL một cách dễ dàng. Access Basic có những khác biệt nhất định so với Visual Basic. Chỉ đến phiên bản Access 7.0. Visual Basis về sau và Access mới dùng chung ngôn ngữ lập trình mà Microsft gọi là VBA - Visual Basis for Application. Ta thấy Access và Visual Basic khác nhau ở cách chế tạo ra các ứng dụng so với các công cụ thiết kế khác nhau nhưng thành phần xử lí CSDL thì có nhiều điểm tương đồng vì cùng sử dụng Jet Engine. Visual Basic cho phép biện dịch các ứng dụng thành tập tin EXE, trong khi Access ta phỉ phân phối luôn cả tài nguyên thiết kế. Khái ngườiệm CSDL trong Access bao gồm cả phần dữ liệu (các bảng) và phần ứng dụng ( query, form, table, report, macro, module ), trong khi đối với các hệ khác, CSDL chỉ bao gồm phần dữ liệu. Chiến lược bảo mật tài nguyên thiết kế phải được đặt lên hàn đầu khi chọn Access làm công cụ phát triển ứng dụng. Hệ thống giao diện hỗ trợ thiết kế ( đặc biệt trong Access ) cũng khá rắc rối khiến người chưa có kinh nghiệm hay lẫn lộn giữa các thức dành cho người dùng cuối và những thứ dành cho người lập trình, thứ chỉ dùng cho thiết kế và thứ có thể mang vào ứng dụng. Chương 4 Các Form trong chương trình 1. Form chính của chương trình 2. Form Danh mục lớp học 3. Danh mục môn học 4. Danh mục Sinh viên 5. Bảng điểm Mã nguồn chương trình 1.FRMABOUT: Option Explicit ' Reg Key Security Options... Const READ_CONTROL = &H20000 Const KEY_QUERY_VALUE = &H1 Const KEY_SET_VALUE = &H2 Const KEY_CREATE_SUB_KEY = &H4 Const KEY_ENUMERATE_SUB_KEYS = &H8 Const KEY_NOTIFY = &H10 Const KEY_CREATE_LINK = &H20 Const KEY_ALL_ACCESS = KEY_QUERY_VALUE + KEY_SET_VALUE + _ KEY_CREATE_SUB_KEY + KEY_ENUMERATE_SUB_KEYS + _ KEY_NOTIFY + KEY_CREATE_LINK + READ_CONTROL ' Reg Key ROOT Types... Const HKEY_LOCAL_MACHINE = &H80000002 Const ERROR_SUCCESS = 0 Const REG_SZ = 1 ' Unicode nul terminated string Const REG_DWORD = 4 ' 32-bit number Const gREGKEYSYSINFOLOC = "SOFTWARE\Microsoft\Shared Tools Location" Const gREGVALSYSINFOLOC = "MSINFO" Const gREGKEYSYSINFO = "SOFTWARE\Microsoft\Shared Tools\MSINFO" Const gREGVALSYSINFO = "PATH" Private Declare Function RegOpenKeyEx Lib "advapi32" Alias "RegOpenKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, ByVal samDesired As Long, ByRef phkResult As Long) As Long Private Declare Function RegQueryValueEx Lib "advapi32" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, ByRef lpType As Long, ByVal lpData As String, ByRef lpcbData As Long) As Long Private Declare Function RegCloseKey Lib "advapi32" (ByVal hKey As Long) As Long Private Sub cmdSysInfo_Click() Call StartSysInfo End Sub Private Sub cmdOK_Click() Unload Me End Sub Public Sub StartSysInfo() On Error GoTo SysInfoErr Dim rc As Long Dim SysInfoPath As String ' Try To Get System Info Program Path\Name From Registry... If GetKeyValue(HKEY_LOCAL_MACHINE, gREGKEYSYSINFO, gREGVALSYSINFO, SysInfoPath) Then ' Try To Get System Info Program Path Only From Registry... ElseIf GetKeyValue(HKEY_LOCAL_MACHINE, gREGKEYSYSINFOLOC, gREGVALSYSINFOLOC, SysInfoPath) Then ' Validate Existance Of Known 32 Bit File Version If (Dir(SysInfoPath & "\MSINFO32.EXE") "") Then SysInfoPath = SysInfoPath & "\MSINFO32.EXE" ' Error - File Can Not Be Found... Else GoTo SysInfoErr End If ' Error - Registry Entry Can Not Be Found... Else GoTo SysInfoErr End If Call Shell(SysInfoPath, vbNormalFocus) Exit Sub SysInfoErr: MsgBox "System Information Is Unavailable At This Time", vbOKOnly End Sub Public Function GetKeyValue(KeyRoot As Long, KeyName As String, SubKeyRef As String, ByRef KeyVal As String) As Boolean Dim i As Long ' Loop Counter Dim rc As Long ' Return Code Dim hKey As Long ' Handle To An Open Registry Key Dim hDepth As Long ' Dim KeyValType As Long ' Data Type Of A Registry Key Dim tmpVal As String ' Tempory Storage For A Registry Key Value Dim KeyValSize As Long ' Size Of Registry Key Variable '------------------------------------------------------------ ' Open RegKey Under KeyRoot {HKEY_LOCAL_MACHINE...} '------------------------------------------------------------ rc = RegOpenKeyEx(KeyRoot, KeyName, 0, KEY_ALL_ACCESS, hKey) ' Open Registry Key If (rc ERROR_SUCCESS) Then GoTo GetKeyError ' Handle Error... tmpVal = String$(1024, 0) ' Allocate Variable Space KeyValSize = 1024 ' Mark Variable Size '------------------------------------------------------------ ' Retrieve Registry Key Value... '------------------------------------------------------------ rc = RegQueryValueEx(hKey, SubKeyRef, 0, _ KeyValType, tmpVal, KeyValSize) ' Get/Create Key Value If (rc ERROR_SUCCESS) Then GoTo GetKeyError ' Handle Errors If (Asc(Mid(tmpVal, KeyValSize, 1)) = 0) Then ' Win95 Adds Null Terminated String... tmpVal = Left(tmpVal, KeyValSize - 1) ' Null Found, Extract From String Else ' WinNT Does NOT Null Terminate String... tmpVal = Left(tmpVal, KeyValSize) ' Null Not Found, Extract String Only End If '------------------------------------------------------------ ' Determine Key Value Type For Conversion... '------------------------------------------------------------ Select Case KeyValType ' Search Data Types... Case REG_SZ ' String Registry Key Data Type KeyVal = tmpVal ' Copy String Value Case REG_DWORD ' Double Word Registry Key Data Type For i = Len(tmpVal) To 1 Step -1 ' Convert Each Bit KeyVal = KeyVal + Hex(Asc(Mid(tmpVal, i, 1))) ' Build Value Char. By Char. Next KeyVal = Format$("&h" + KeyVal) ' Convert Double Word To String End Select GetKeyValue = True ' Return Success rc = RegCloseKey(hKey) ' Close Registry Key Exit Function ' Exit GetKeyError: ' Cleanup After An Error Has Occured... KeyVal = "" ' Set Return Val To Empty String GetKeyValue = False ' Return Failure rc = RegCloseKey(hKey) ' Close Registry Key End Function Private Sub lblDescription_Click() End Sub Private Sub lblDisclaimer_Click() End Sub 2.FRMADDLH: Option Explicit Private Sub cmdExit_Click() Unload Me End Sub Private Sub cmdOK_Click() If Trim(txtName.Text) = "" Or Trim(txtKhoaHoc.Text) = "" Or Trim(txtId.Text) = "" Then MsgBox "Thông tin về lớp học cần được nhập đầy đủ.", vbInformation, "Thông báo" Exit Sub End If If IsNumeric(txtKhoaHoc.Text) = False Then MsgBox "Khoá học cần được nhập theo dạng số.", vbInformation, "Thông báo" Exit Sub End If txtKhoaHoc.Text = CInt(txtKhoaHoc.Text) If v_Add = True Then If gFTenLop(txtId.Text) = "" Then gDbe.BeginTrans gSql = "Insert into LopHoc (MSLop,TenLop,KhoaHoc) " & _ " Values ('" & UCase(txtId.Text) & "', '" & txtName.Text & "', " & Trim(txtKhoaHoc.Text) & ")" gDb.Execute gSql gDbe.CommitTrans Call s_ClearText FrmLopHoc.Adodc1.Refresh FrmLopHoc.TDBGrid1.Refresh Unload Me Else MsgBox "Bạn nhập trùng mã số lớp học.", vbCritical, "Error" txtId.SetFocus Exit Sub End If Else gDbe.BeginTrans gSql = "Update LopHoc Set TenLop='" & txtName.Text & "', KhoaHoc = " & Trim(txtKhoaHoc.Text) & " " & _ "Where MSLop='" & v_IdEdit & "'" gDb.Execute gSql gDbe.CommitTrans DoEvents FrmLopHoc.Adodc1.Refresh FrmLopHoc.TDBGrid1.Refresh Unload Me End If End Sub Private Sub Form_Load() If v_Add = True Then txtId.Enabled = True Else txtId.Enabled = False txtId.Text = v_IdEdit txtName.Text = gFTenLop(v_IdEdit) txtKhoaHoc.Text = gKhoaHoc End If End Sub Private Sub s_ClearText() txtId.Text = "" txtName.Text = "" txtKhoaHoc.Text = "" End Sub 3.FRMADDMH: Option Explicit Private Sub cmdExit_Click() Unload Me End Sub Private Sub cmdOK_Click() If Trim(txtName.Text) = "" Or Trim(txtHocKy.Text) = "" Or Trim(txtId.Text) = "" Or Trim(txtSotrinh.Text) = "" Then MsgBox "Thông tin về môn học cần được nhập đầy đủ.", vbInformation, "Thông báo" Exit Sub End If If IsNumeric(txtHocKy.Text) = False Or IsNumeric(txtSotrinh.Text) = False Then MsgBox "Học kỳ, Số trình cần được nhập theo dạng số.", vbInformation, "Thông báo" Exit Sub End If txtHocKy.Text = CInt(txtHocKy.Text) txtSotrinh.Text = CInt(txtSotrinh.Text) If v_Add = True Then If gFTenMon(txtId.Text) = "" Then gDbe.BeginTrans gSql = "Insert into MonHoc (MSMon,TenMon,HocKy,SoTrinh) " & _ " Values ('" & UCase(txtId.Text) & "', '" & txtName.Text & "', " & Trim(txtHocKy.Text) & ", " & Trim(txtSotrinh.Text) & ")" gDb.Execute gSql gDbe.CommitTrans Call s_ClearText FrmMonHoc.Adodc1.Refresh FrmMonHoc.TDBGrid1.Refresh Unload Me Else MsgBox "Bạn nhập trùng mã số môn học.", vbCritical, "Error" txtId.SetFocus Exit Sub End If Else gDbe.BeginTrans gSql = "Update MonHoc Set TenMon='" & txtName.Text & "', HocKy = " & Trim(txtHocKy.Text) & ", SoTrinh = " & Trim(txtSotrinh.Text) & " " & _ "Where MSMon='" & v_IdEdit & "'" gDb.Execute gSql gDbe.CommitTrans DoEvents FrmMonHoc.Adodc1.Refresh FrmMonHoc.TDBGrid1.Refresh Unload Me End If End Sub Private Sub Form_Load() Dim rst As Recordset If v_Add = True Then txtId.Enabled = True Else txtId.Enabled = False txtId.Text = v_IdEdit Set rst = gDb.OpenRecordset("Select * From MonHoc Where MSMon='" & v_IdEdit & "'") If rst.EOF = False Or rst.BOF = False Then rst.MoveFirst txtName.Text = rst!TenMon txtHocKy.Text = rst!HocKy txtSotrinh.Text = rst!SoTrinh End If rst.Close End If End Sub Private Sub s_ClearText() txtId.Text = "" txtName.Text = "" txtHocKy.Text = "" txtSotrinh.Text = "" End Sub 4.FRMBANGDIEM: Option Explicit Private Sub CmChapNhan_Click() On Error GoTo Err_ If Adodc1.Recordset.EOF = False Then Adodc1.Recordset.MoveNext End If gDbe.BeginTrans gSql = "Delete From BangDiem Where BangDiem.MSMon = '" & gMSMon & _ "' And BangDiem.MSSV In (Select Distinct MSSV From BangDiemTam)" gDb.Execute gSql gSql = "Insert Into BangDiem (MSSV, Diem1, Diem2) " & _ "Select MSSV, Diem1, Diem2 From BangDiemTam" gDb.Execute gSql gSql = "Update BangDiem Set MSMon = '" & gMSMon & "' Where IsNull(MSMon)" gDb.Execute gSql gDb.Execute "Update BangDiem Set Diem2 = Null Where Diem1>=5" gDbe.CommitTrans Unload Me Exit Sub Err_: MsgBox Err.Number & " - " & Err.Description, vbCritical, "Error" gDbe.Rollback End Sub Private Sub CmHuyBo_Click() Unload Me End Sub Private Sub Form_Activate() If Adodc1.Recordset.EOF = True And Adodc1.Recordset.BOF = True Then MsgBox "Không tồn tại bản ghi", vbInformation, "Thông báo" 'Unload Me End If End Sub Private Sub Form_Load() With Adodc1 .ConnectionString = gConn.ConnectionString .CommandType = adCmdTable .CursorLocation = adUseClient .RecordSource = "BangDiemTam" .Refresh End With Select Case gForm Case 2 ' Nhập điểm thi lần 1 TDBGrid1.Columns(3).Visible = False Me.Caption = "Nhập điểm thi lần 1 của môn: " & gMSMon & " - " & gFTenMon(gMSMon) Case 3 ' Nhập điểm thi lần 2 TDBGrid1.Columns(2).Visible = False Me.Caption = "Nhập điểm thi lần 2 của môn: " & gMSMon & " - " & gFTenMon(gMSMon) End Select With TDBGrid1 .Width = .Width - .Columns(3).Width FrmBangDiem.Width = FrmBangDiem.Width - .Columns(3).Width CmChapNhan.Left = CmChapNhan.Left - (.Columns(3).Width \ 2) CmHuyBo.Left = CmHuyBo.Left - (.Columns(3).Width \ 2) End With End Sub Private Sub OpDiem_Click() With Adodc1 .ConnectionString = gConn.ConnectionString .CommandType = adCmdText .CursorLocation = adUseClient If gForm = 2 Then .RecordSource = "Select * From BangDiemTam Order by Diem1 Desc" ElseIf gForm = 3 Then .RecordSource = "Select * From BangDiemTam Order by Diem2 Desc" End If .Refresh End With End Sub Private Sub OpHoTen_Click() With Adodc1 .ConnectionString = gConn.ConnectionString .CommandType = adCmdText .CursorLocation = adUseClient .RecordSource = "Select * From BangDiemTam Order by HoTen" .Refresh End With End Sub Private Sub OpMSSV_Click() With Adodc1 .ConnectionString = gConn.ConnectionString .CommandType = adCmdText .CursorLocation = adUseClient .RecordSource = "Select * From BangDiemTam Order by MSSV" .Refresh End With End Sub Private Sub TDBGrid1_Click() End Sub 5.FRMBANGDIEMSINHVIEN: Option Explicit Private Sub cm

Các file đính kèm theo tài liệu này:

  • doc37022.doc
Tài liệu liên quan