Đề tài Chương trình quản lý nhân sự của Ngân hàng chính sách xã hội Huyện Ngọc Lặc Tỉnh Thanh Hóa

Khi có nhân viên được khen thưởng hay bị kỷ luật thì người dùng phải cập nhật vào cơ sở dữ liệu bằng cách Thêm mới một bản ghi tong Form này. Với một nhân viên thì trong 1 ngày chỉ có thể có 1 hình thức là khen thưởng hay kỷ luật và không thể có 2 lần khen thương hay kỷ luật trong cùng 1 ngày được. Khi muốn điều chỉnh thông tin khen thương ky luật thì người dùng có thể Sửa và lưu ý là chỉ được sửa hai trường đó là Hình thức và Mức độ. Khi nhân viên hết thời hạn ky luật người quan trị nhân vào nút Xóa để hủy bỏ kỷ luật với nhân viên đó.

doc77 trang | Chia sẻ: lvcdongnoi | Lượt xem: 2502 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Đề tài Chương trình quản lý nhân sự của Ngân hàng chính sách xã hội Huyện Ngọc Lặc Tỉnh Thanh Hóa, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ời hạn (hoặc lãi xuất) Thời hạn (hoặc lãi xuấ nợ) Văn bản duyệt Số ngày Cấp ra quyết định Ngày có hiệu lực V- Đánh giá TSBĐ tiền vay và những thay đổi theo định kỳ:.............................. Hợp đồng tất toán ngày........ tháng....... năm ........... Trưởng phòng DVKH 4. Biên bản kiểm tra thực tế khách hàng: Dành cho Phòng tín dụng và các phòng Dịch vụ khách hàng CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM Độc lập - Tự do - Hạnh phúc BIÊN BẢN KIỂM TRA THỰC TẾ KHÁCH HÀNG Hôm nay, ngày... tháng... năm ... . Chúng tôi gồm có: A/ Đại diện Ngân hàng CSXH .................. - B/ Đại diện Doanh nghiệp:........................ - Sau khi tiến hành kiểm tra sổ sách chứng từ và thực tế, hai bên thống nhất một số nội dung như sau: I. Tình hình thực hiện kế hoạch SXKD trong kỳ: Giá trị sản lượng. Doanh thu. Lợi nhuận. Các khoản nộp. Số lượng CBCNV đang làm việc: II. Tình hình quan hệ tín dụng trong kỳ: Dư nợ đầu kỳ: Doanh số trả nợ: Doanh số vay: Cụ thể: Số món vay, số tiền vay, tiền mặt,..... - Đánh giá mục đích sử dụng vốn vay: Thông qua các hoá đơn, chứng từ thu chi, ghi chép trên sổ quỹ tiền mặt, tiền gửi, (tính cập nhật, chính xác,...). - Giá trị vật tư đảm bảo nợ vay: Đủ hay thiếu. +/ Tài sản lưu động: +/ Các khoản loại trừ: +/ Nợ ngắn hạn: Trong đó dư vay ngắn hạn Ngân hàng. +/ Nguồn vốn lưu động tự có: - Kiểm tra tại hiện trường: Thị sát vật chất (vật tư, hàng hoá,...), đánh giá.. - Kiểm tra các biện pháp bảo đảm tiền vay: Dư nợ cuối kỳ: III. Nhận xét và kiến nghị: Trong sản xuất kinh doanh. Trong quan hệ tín dụng. Kiến nghị. ĐẠI DIỆN NGÂN HÀNG ĐẠI DIỆN ĐƠN VỊ 5. Giấy giao nhận tài sản: CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM Độc lập - Tự do - Hạnh phúc BIÊN BẢN GIAO NHẬN TÀI SẢN - HỒ SƠ TÀI SẢN THẾ CHẤP, CẦM CỐ Căn cứ Hợp đồng thế chấp số............. ngày ....... tháng ...... năm .......... giữa ......... ...............và Ngân hàng Chính sách xã hội Việt nam - Chi nhánh Thanh Hóa Hôm nay, ngày......tháng........năm .......... tại ............................................. Chúng tôi gồm có: - Tên Bên vay: ................................................................................................... Người giao hồ sơ trực tiếp : - Chi nhánh Ngân hàng Chính sách xã hội Thanh Hóa. Người nhận hồ sơ trực tiếp Hai bên đã tiến hành việc giao nhận tài sản thế chấp cầm cố, hồ sơ về tài sản thế chấp, cầm cố của ................................................................ cho Chi nhánh Ngân hàng Chính sách xã hội Thanh Hóa, bao gồm: Tài sản:........................................................................................................ Hồ sơ :.......................................................................................................... Bên nhận Bên giao Hôm nay, ngày...... tháng ..... năm....... Chi nhánh Ngân hàng Chính sách xã hội Thanh Hóa và .....................................................................................đã tiến hành việc bàn giao tài sản, hồ sơ về tài sản thế chấp, cầm cố như sau: Tài sản cầm cố:.................................................................................................... ............................................................................................................................. Các giấy tờ về tài sản thế chấp, cầm cố............................................................... ............................................................................................................................. Ngày.... tháng ... năm.... BÊN NHẬN BÊN GIAO 6. Phiếu tiếp nhân hồ sơ khách hàng: CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM Độc lập - Tự do - Hạnh phúc PHIẾU TIẾP NHẬN HỒ SƠ KHÁCH HÀNG, KHOẢN VAY VỐN Hôm nay, ngày....tháng.......năm 200........tại...................................................... Chúng tôi gồm có: A/ Bên giao hồ sơ :.................................................. Người trực tiếp giao hồ sơ:...................... B/ Bên nhận hồ sơ :................................................ Người trực tiếp nhận hồ sơ:.............................. Hai bên thống nhất như sau: 1. Bên giao chuyển cho Bên nhận một bộ hồ sơ gồm cú cỏc tài liệu theo danh mục như sau: +...................................................................................................................... +...................................................................................................................... +...................................................................................................................... +......................................................................................................................... +...................................................................................................................... +...................................................................................................................... +...................................................................................................................... +...................................................................................................................... 2. Bên nhận hồ sơ hướng dẫn và đề nghị Bên giao hồ sơ gửi bổ sung cỏc tài liệu sau: +...................................................................................................................... +...................................................................................................................... +...................................................................................................................... +...................................................................................................................... Bên nhận chịu trách nhiệm bảo quản các tài liệu nhận được không bị hư hỏng hay thất lạc. Ngày.... tháng ... năm.... Bên giao hồ sơ Bên nhận hồ sơ ( Ký, ghi rõ họ tên) ( Ký, ghi rõ họ tên) C. Báo cáo kết quả tài chính của Ngân hàng năm 2010 Chỉ tiêu Năm 2008 Năm 2009 Năm 2010 A. THU NHẬP 674.603 1.115.450 1.730.391 Thu từ lãi cho vay 436.628 602.872 804.858 Thu khác từ hoạt động tín dụng 130 5229 5.073 Thu lãi tiền gửi 14.206 14.123 26.235 Thu dịch vụ thanh toán 1 31 114 Thu từ dịch vụ ngân quỹ - 1 1 Thu từ hoạt động khác 1.892 183 4.025 Thu cấp bù chênh lẹch lãi xuất 219.866 494.108 886.136 Các khoản thu nhập khác 1.880 3.060 3.125 B. CHI PHÍ 711.209 1.179.992 1.662.615 Chi về huy động vốn 272.963 486.517 717.837 Chi dịch vụ thanh toán và ngân quỹ 1.562 4.962 8.697 Chi trả phí dịch vụ ủy thác cho vay 234.146 271.936 258.781 Chi về tài sản 43.998 77.704 194.543 Chi cho nhân viên 83.051 209.542 301.176 Chi hoạt động quan lý công cụ 56.605 92.087 140.820 Chi trích lập dự phòng 18.361 36.108 38.934 Chi phí khác 523 1.136 1.197 C. Chênh lệch THU-CHI 36.606 64.542 67.776 1.2. Hệ thống quản lý nhân sự của Ngân hàng CSXH huyện Ngọc Lặc Tỉnh Thanh Hóa 1.2.1. Sự hạn chế của hệ thống quản lý cũ Việc quản lý Nhân sự của toàn chi nhánh do phòng Nhân sự quản lý. Do cơ quan ngày càng phát triển, số lượng nhân viên ngày càng đông cho nên số lượng hồ sơ sổ sách ngày càng nhiều. Việc xử lý thông tin thủ công dễ dẫn đến sự sai lệch về dữ liệu, việc tìm kiếm, đối chiếu và chỉnh sửa rất khó khăn, mất nhiều thời gian và công sức. Với nguồn tài nguyên có sẵn của cơ quan cũng như số lượng nhân viên ngày càng đông yêu cầu cơ quan phải có một sự đổi mới trong quá trình quản lý kinh doanh. Áp dụng công nghệ thông tin vào trong việc quản lý để hỗ trợ cho các nhân viên trong cơ quan, đồng thời làm giảm đi công sức và nhân lực phải bỏ ra trong hoạt động chung của cơ quan mình. Bằng cách đó, không những chỉ tích kiệm được công sức và tiền của cho cơ quan mà còn tạo ra được một khả năng hoạt động linh hoạt, nhanh chóng và an toàn cho công tác quản lý điều hành. Việc xử lý thông tin thủ công dẫn đến việc tìm kiếm, đối chiếu rất khó khăn, mất nhiều thời gian. Vì vậy rất khó chỉnh sửa và tìm kiếm dữ liệu. Vì thế việc thiết kế một hệ thống quản lý thông tin nhân sự trong cơ quan nhằm khắc phục những hạn chế nói trên là nhu cầu thực tế và cần thiết. 1.2.2. Đề xuất hệ thống quản lý mới Để khắc phục những nhược điểm của hệ thống quản lý nhân sự hiện tại và đưa công cụ tin học phục vụ công tác quản lý nhân sự, ta thiết kế một hệ thống mới với những đặc trưng sau : - Có sự tham gia của máy tính, cập nhận thông tin, sắp xếp, kiết xuất được xử lý tự động. - Dữ liệu đầu vào được nhập từ bàn phím, dữ liệu đầu ra là những báo cáo, hồ sơ phục vụ cho công tác quản lý. Phần mềm quản lý nhân sự dùng cho ngân hàng là công tác quản lý nhân sự cho toàn cơ quan. Phần quản lý nhân sự của cơ quan với mục đích là thực hiện công việc nhanh chóng, chính xác, tiết kiệm công sức cho người làm công tác quản lý. Việc xây dựng phần mề này có một quá trình phân tích tỉ mỉ và khoa học, nhằm cài đặt một chương trình ứng dụng đưa vào thực tế cho nhà máy. * Bài toán phải đáp ứng được các yêu của cơ quan như sau: - Cho phép nhập, sửa, xóa thông tin nhân sự vào hệ thống từ bàn phím máy tính. - Chương trình tự động tổng hợp, tìm kiếm, cho kết quả theo đúng yêu cầu như: + Tìm kiếm nhân viên, phòng ban, chức vụ… + Tìm kiếm các hợp đồng lao động mà cơ quan đã ký. + Thống kê được các nhân sự của cơ quan. + Tính toán lương cho nhân viên một cách cụ thể + Báo cáo về tình trạng làm việc của nhân viên ( khen thưởng, kỷ luật). - Chương trình giúp việc thực hiện nhanh chóng, đơn giản và dễ sử dụng. Đặc biệt các dữ liệu kết xuất chính xác, nhất quán cho người sử dụng. - Có trợ giúp và thông báo lỗi khi xảy ra lỗi để người sử dụng dễ sử dụng chương trình hơn. - Có hình thức phù hợp để bảo mật thông tin và phân quyền người dùng. - Chương trình dễ cài đặt và chạy tốt cho máy PC đang có các phần mềm ứng dụng phổ biến. Có thể nâng cấp để phù hợp với sự phát triền của thiết bị phần cứng và các phần mềm ứng dụng trong tương lai. 1.2.3 . Ưu điểm của hệ thống quản lý nhân sự mới - Quá trình xử lý dữ liệu nhanh cho kết quả chính xác. - Giảm bớt thời gian tính toán cho nhân viên quản lý đặc biệt là công việc tìm kiếm, tổng hợp, báo cáo - thống kê. - Khả năng lưu trữ thông tin rất lớn của đĩa từ tạo thêm một phương tiện lưu trữ thông tin (ngoài lưu trữ trên giấy) đảm bảo tăng cường khả năng an toàn cho dữ liệu. - Các mẫu biểu báo cáo in ra có hình thức đẹp, chất lượng tốt đáp ứng được yêu cầu của cơ quan về quản lý nhân sự. - Tăng tính đồng bộ với các hệ thống quản lý khác, tăng tính hấp dẫn phục vụ cho sự phát triển chung của cơ quan. - Có thể nâng cao tính bảo mật thông tin trong lưu trữ và quản lý. CHƯƠNG 2 PHÂN TÍCH THIẾT KẾ HỆ THỐNG 2.1 Phân tích hệ thống 2.1.1 Thông tin đầu vào Khi tuyển dụng nhân viên, cơ quan sẽ lưu trữ thông tin cá nhân của mỗi nhân viên theo mẫu thống nhất. Ngoài ra còn có các thông tin thay đổi về thông tin cá nhân cũng như các thông tin về khen thưởng, kỷ luật, đào tạo,… được thêm vào hồ sơ cá nhân của các nhân viên trong quá trình công tác. ٭ Luồng dữ liệu vào Các thông tin nhân sự: - Lý lịch nhân sự. - Khen thưởng, kỷ luật. - Thình độ chuyên môn. - Lương nhân viên * Cách tính lương nhân viên: Lương thực lĩnh = Lương cơ bản * HS Lương * HSBH + Thưởng - Khấu trừ Khấu trừ = Thuế TNCN + Bảo hiểm Xã hội + Bảo hiểm thất nghiệp + BH y tế 2.1.2 Thông tin đầu ra - Thống kê, tìm kiếm theo yêu cầu. - In các báo cáo theo yêu cầu. - Đưa ra được kết quả tìm kiếm về nhân viên, phòng ban, chức vụ. - Đưa ra được kết quả tìm kiếm nhân viên có khen thưởng, kỷ luật. - Thống kê được các nhân sự của cơ quan. 2.1.3 Mục tiêu quản lý - Lưu trữ, cập nhật thông tin của nhân viên trong cơ quan. - Tìm kiếm thông tin của các nhân viên. - Đưa ra báo cáo và thống kê về các thông tin nhân viên . - Đưa ra báo cáo và thống kê về Lương nhân viên . 2.1.4. Biểu đồ phân cấp chức năng (BFD) QUẢN LÝ NHÂN SỰ Cập nhật Cập nhật hồ sơ nhân viên Cập nhật Trình độ văn hóa Cập nhật Khen thưởng,kỷ luật Tìm kiếm Tìm kiếm theo tên nhân viên Tìm kiếm theo Chức vụ Tìm kiếm theo phòng ban Tìm kiếm theo trình độ VH Cập nhật Phòng ban Cập nhật Chức vụ Cập nhật Bảng chấm công Thống kê, báo cáo Thống Kê Hồ sơ Nhân viên Thống Kê Phòng ban Thống kê Chức vụ Khen thưởng, kỷ luật Cập nhật Diễn biến lương Tìm kiếm theo Đối tượng LĐ 2.1.5. Biểu đồ luồng dữ liệu khung cảnh Quản lý nhân sự Cán bộ quản lý Nhân sự Thông tin yêu cầu Thông tin trả lời Hồ sơ thông tin cá nhân Các y/c về thông tin nhân sự 2.1.6. Biểu đồ luồng dữ liệu mức đỉnh Cán Bộ Quản lý Tìm kiếm Cán Bộ quản lý HỒ SƠ NHÂN SỰ Danh mục phòng ban Danh mục lương Cập nhật Thống kê báo cáo Y/C tim kiếm Yêu cầu thống kê K/Q tìm kiếm Kết quả thống kê Thông tin nhân sự Kết quả T.Tin bảng lương T.Tin nhân sự T/tin phòng ban 2.1.7. Biểu đồ luồng dữ liệu mức dưới đỉnh (Cập nhật nhân sự) Chức vụ Cập nhật phòng ban Cập nhật diễn biến Lương Phòng ban Diễn biến lương HỒ SƠ NHÂN SỰ Khen thưởng KL T/tin nhân viên D/s phòng ban TĐVH Cập nhật trình độ VH Cập nhật hồ sơ Nhân viên CN Khen thưởng Kỷ Luật DS khen thưởng kỷ luật Diễn biến lương T.Tin chức vụ Cập nhật chức vụ T.Tin TĐVH Cập nhật Bảng chấm công Bảng chấm công T/tin ngày công Cán bộ quản lý 2.1.8. Biểu đồ luồng dữ liệu mức dưới đỉnh (Tìm kiếm) Tìm kiếm theo Phòng ban Tìm kiếm theo Trình độ VH Tìm kiếm theo Tên nhân viên Hồ sơ cán bộ CÁN BỘ QUẢN LÝ Kết quả YC TK theo phòng ban YC TK theo trình độ VH Kết quả Kết quả Phòng ban Hồ sơ cán bộ Trình độ Tìm kiếm theo chức vụ Kết quả YC TK theo Chức vụ YC TK theo tên Nhân viên Tìm kiếm theo Đối tượng LĐ YC TK theo Đối tượng LĐ Kết quả Đối tượng Tên NV Chức vụ 2.1.9. Sơ đồ luồng dữ liệu mức dưới đỉnh (Thống kê báo cáo) Yêu cầu T/Kê khen thưởng, kỷ luật Cán bộ quản lý TK theo phòng Ban TK theo DS nhân viên TK theo Chức vu Phòng ban Kết quả TK thống kê khen thưởng kỷ luật Khen thưởng kỷ luật Y/C TK DS nhân viên YC T/Kê theo phòng ban Kết quả TK Kết quả TK YC T/Kê theo phòng ban Kết quả TK 2.2. Thiết kế hệ thống về dữ liệu 2.2.1. Các thực thể và thuộc tính 1 - Thực thể NhanVien lưu trữ tất cả các thông tin về hồ sơ, lý lịch của nhân viên. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaNV Text Mã nhân viên 2 Hoten Text Họ tên nhân viên 3 Ngaysinh Text Ngày sinh 4 Gioitinh Text Giới tính 5 MaCV Text Mã Chức Vụ 6 MaPB Text Mã Phòng Ban 7 MaTD Text Mã Trình Độ 8 Chuyenmon Text Chuyên Môn 9 Ngayvaodang Text Ngày Vào Đảng 10 Nguyenquan Text Nguyên Quán 11 HKthuongtru Text Hộ Khẩu Thường Trú 12 SoCMT Text Số Chứng Minh Thư 13 Ngaycap Text Ngày Cấp 14 Noicap Text Nơi Cấp 15 HotenBo Text Họ Tên Bố 16 NghenghiepBo Text Nghề Nghiệp Bố 17 HotenMe Text Họ Tên Mẹ 18 NghenghiepMe Text Nghề Nghiệp Mẹ 2 - Thực thể ChamCong lưu trữ chi tiết các ngày công đi làm của nhân viên, trong đó có cả các ngày nghỉ, ngày lễ và nghỉ phép . Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaNV Text Mã Nhân Viên 2 NgayBT Number Ngày Bình Thường 3 Chunhat Number Chủ Nhật 4 Ngayle Number Ngày Lễ 5 Tangca Number Tăng Ca 6 Nghiphep Number Nghỉ Phép 3 - Thực thể BangLuong lưu trữ các thông tin về tính lương cho hân viên. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaNV Text Mã nhân viên 2 Luong Text Lương 3 HSluong Text Hệ Số Lương 4 Hsbaohiem Text Hệ Số Bảo Hiểm 5 Khautru Text Khấu Trừ 6 Thuong Text Thường 7 Tamung Text Tạm Ứng 8 Hotro Text Hỗ Trợ 4 - Thực thể TrinhDoVH lưu trình độ văn hóa của nhân viên liên quan trực tiếp đến hệ số để tính lương. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaTD Text Mã Trình Độ 2 TenTD Text Tên Trình Độ 5 - Thực thể KhenThuongKyLuat lưu trữ các thông tin về hình thức khen thưởng, kỷ luật đối với nhân viên. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaNV Text Mã nhân viên 2 Ngay Date / Time Ngày 3 Hinhthuc Text Hình Thức 4 Mucdo Text Mức Độ 6 - Thực thể ChucVu lưu dữ liệu về chức vụ nhân viên. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaCV Text Mã Chức Vụ 2 TenCV Text Tên Chức Vụ 3 MaDT Text Mã Dân Tộc 7 - Thực thể DoiTuongLD lưu các thông tin về đối tượng lao động là nhân viên chính thức, nhân viên hợp đồng hay thử việc. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaDT Text Mã Đối tượng 2 TenDT Text Tên Đối tượng 8 - Thực thể PhongBan lưu dữ liệu về phòng ban của công ty. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 MaPB Text Mã Phòng Ban 2 TenPB Text Tên Phòng Ban 3 Makhoi Text Mã Khối 9 - Thực thể KhoiDH lưu dữ liệu về các khối điều hành để phân chia các lĩnh vực hoạt động riêng biệt của các phòng ban. Các thuộc tính được mô tả như sau: STT Tên thuộc tính Kiểu dữ liệu Mô tả 1 Makhoi Text Mã Khối 2 Tenkhoi Text Tên Khối 2.2.2. Sơ đồ liên kết giữa các thực thể Nhân viên Nhân viên Đối tượng Trình độ VH Nhân viên Chức vụ Phòng ban Khối ĐH Chấm công Bảng Lương Chức vụ Nhân viên Khen thưởng Kỷ luật Nhân viên Nhân viên Phòng ban CHƯƠNG 3 XÂY DỰNG CƠ SỞ DỮ LIỆU VÀ CÀI ĐẶT HỆ THỐNG 3.1. Cơ sở lý thuyết 3.1.1. Tổng quan về Hệ quản trị cơ sở dữ liệu Microsoft Access 2003 Microsoft Access 2003 là một trong bốn ứng dụng chính của Microsoft Office 2003, được dùng để tạo ra và quản trị một cơ sở dữ liệu. Bảng là trung tâm của mọi cơ sở dữ liệu vì nó chứa các dữ liệu. Trong Access một bảng được hiển thị dưới dạng một trong hai khung nhìn (View): Khung nhìn thiết kế (Design view) hoặc khung nhìn trang dữ liệu (Datasheet view). Khung nhìn thiết kế được dùng để định nghĩa bảng ban đầu và chỉ ra các trường của nó. Khung nhìn trang dữ liệu được dùng để thêm vào, sửa đổi hoặc loại bỏ các bản ghi. Tại một thời điểm chúng ta chỉ có thể làm việc với một dòng. Mỗi một bảng nhất thiết phải có một khóa chính (Primary key). Đó là một trường hoặc một nhóm các trường có giá trị khác nhau trên mỗi bản ghi. 3.1.2. Tổng quan vể ngôn ngữ lập trình Microsoft Visual Basic 6.0 Visual Basic là một công cụ lập trình trực quan của Microsoft, giúp ta xây dựng nhanh các ứng dụng trên Windows. Khác với môi trường lập trình hướng thủ tục trước đây. Visual Basic là môi trường lập trình hướng sự kiện trên Windows. Visual Basic cung cấp một bộ công cụ hoàn chỉnh để đơn giản hoá việc triển khai lập trình ứng dụng. Khi viết một chương trình trong Visual Basic ta cần phải thực hiện qua 2 bước là: Thiết kế giao diện và Viết lệnh. Trong chương trình Visual Basic đều có ít nhất là một Form. Form hay còn gọi là biểu mẫu, là thành phần quan trọng nhất trong số tất cả các thành phần giao diện. Form là cơ sở cho việc thiết kế giao diện người dùng của ứng dụng. Tất cả các thành phần tạo thành giao diện người dùng đều được đặt trong Form. Với Visual basic, từ các Form ta có thể kết nối chúng với cơ sở dữ liệu để truy xuất thông tin hay ghi thông tin vào cơ sở dữ liệu để lưu trữ. Nó rất thuận tiện cho việc thiết kế các chương trình phần mềm quản lý. 1. Một số kiểu dữ liệu cơ bản Kiểm soát nội dung của dữ liệu. Visual Basic dùng kiểu Variant như là kiểu mặc định. Ngoài ra, một số kiểu dữ liệu khác cho phép tối ưu hóa về tốc độ và kích cỡ chương trình. Khi dùng Variant, ta không phải chuyển đổi giữa các kiểu dữ liệu, VB tự động làm việc đó. a. Kiểu số Integer, Long, Double, và Currency. Kiểu số tốn ít vùng chứa hơn kiểu Variant.Tất cả biến kiểu số có thể được gán cho nhau và cho biếnVariant.VB làm tròn thay vì chặt bỏ phần thập phân trước khi gán nó cho số Integer. Kiểu Integer tốn ít vùng nhớ hơn các kiểu khác, nó thường dùng làm biến đếm trong các vòng lặp For…Next. Kiểu Single, Double, Currency dùng cho các số có vùng thập phân.Currency hỗ trợ đến 4 chữ số thập phân và 15 chữ số cho phần nguyên, dùng cho các tính toán về tiền tệ. Hàm Round làm tròn số. Ví dụ: Round (12.3456789, 4) trả về 12.3457. b. Kiểu Byte Thường dùng để chứa dữ liệu nhị phân. Tất cả thao tác trên kiểu Integer có thể thực hiện trên kiểu byte, ngoại trừ dấu. Vì byte là kiểu không dấu ( trong khoảng từ 0-255), nó không thể nhận ra số âm. c. Kiểu String Mặc định, biến hay tham số kiểu chuỗi có chiều dài thay đổi, nó có thể tăng hoặc giảm tùy theo ta gán dữ liệu. Ta có thể khai báo chuỗi có chiều dài cố định:Dim EmpName As String * 50 Nếu ta gán một chuỗi ngắn hơn 50 ký tự, EmpName sẽ được thêm vào phần đuôi các ký tự khoảng trắng cho đầy 50 ký tự, nếu chuỗi gán vào dài hơn 50 ký tự, VB tự động chặt bỏ. Khi làm việc với chuỗi, ta cần dùng các hàm Trim và RTrim để cắt bỏ các ký tự trắng không cần thiết. Ngoài ra, một số hàm thông dụng để thao tác trên chuỗi như: + Len: lấy chiều dài chuỗi + Mid$: trích chuỗi con từ giữa chuỗi gốc + Left$: trích chuỗi con từ phần đầu chuỗi gốc + Right$: trích chuỗi con từ phần đuôi của chuỗi gốc + InStr: tìm chuỗi con trong chuỗi gốc. Nếu hàm InStr trả về 0, nghĩa là không tìm thấy. Tìm kiếm không phân biệt cỡ chữ, nhưng nếu tham số thứ 3 là vbBinaryCompare thì đây là tìm kiếm chuỗi có phân biệt chữ in hoa chữ thường. + Replace: tìm và thay thế chuỗi. Nó có tham số cuối cùng tương tự hàm InStr(), cho biết có phân biệt chữ hoa chữ thường hay không. Chuỗi có chiều dài cố định được khai báo Public hay Private trong modul chuẩn. Trong modul của biểu mẫu hoặc modul lớp, nó phải được khai báo Private.VB cho phép chuyển đổi một chuỗi thành một số nếu chuỗi đang thể hiện một con số. Ngược lại ta cũng có thể chuyển một số thành một chuỗi, tuy nhiên nên cẩn thận vì chuyển một chuỗi có giá trị không phải số sẽ gây lỗi lúc chương trình thi hành. d. Kiểu Boolean Nếu ta có một biến có 2 giá trị True/Fasle, Yes/No, On/Off, ta nên dùng kiểu Boolean. Giá trị mặc định của Boolean là Fasle. e. Kiểu Date Khi các kiểu dữ liệu khác được chuyển sang Date, giá trị đứng trước dấu chấm là ngày, giá trị đứng sau dấu chấm là giờ, nửa đêm là 0, giữa ngày là 0.5. Dấu âm thể hiện ngày trước 30/12/1999. Kiểu Date đã giải quyết vấn đề y2k. Dấu # cho biết là kiểu dữ liệu Date, không phải một biểu thức toán học. Tuy nhiên định dạng ngày tháng hiển thị phụ thuộc vào quy định của Window. f. Kiểu Object Biến kiểu này chứa một địa chỉ 4 byte (32 bit) trỏ đến đối tượng trong ứng dụng hiện hành hoặc các ứng dụng khác. Dùng lệnh Set để chỉ ra đối tượng thực sự: Dim objectDb As Object Set objectDb = OpenDatabase (“c:\vb5\Biblio.mdb”) Khi khai báo biến đối tượng, nên chỉ ra tên lớp tường minh, (như TextBox thay vì control, DataBase thay vì Object), ứng dụng sẽ chạy nhanh hơn. g. Kiểu Variant Có thể chứa mọi loại dữ liệu, chuỗi , số, thậm chí mảng. Ta không cần chuyển đổi dữ liệu, VB làm việc đó một cách tự động. Variant cũng thuận tiện khi không biết trước kiểu dữ liệu. Tuy nhiên cần lưu ý: + Nếu muốn thi hành các hàm số học, Variant phải chứa giá trị số. + Nếu muốn nối chuỗi, dùng toán tử & thay vì toán tử +. - Giá trị Empty: Đôi khi ta cần kiểm tra một giá trị có được gán cho biến hay chưa. Biến Variant có giá trị Empty trước khi nó được gán giá trị. Giá trị Empty là giá trị đặc biệt không phải zero, không phải chuỗi rỗng, không phải giá trị null. Ta dùng hàm IsEmpty để kiểm tra giá trị Empty. Khi một biến Variant chứa giá trị Empty, ta có thể dùng nó trong biểu thức, nó có thể được xem là 0 hoặc chuỗi rỗng tùy theo biểu thức. Giá trị Empty biến mất khi có một giá trị bất kỳ được gán cho Variant, muốn trở về giá trị Empty, ta gán từ khóa Empty cho Variant. - Giá trị Null: Biến Variant chứa giá trị Null dùng trong những ứng dụng cơ sở dữ liệu thể hiện không có dữ liệu hoặc dữ liệu không xác định. Dùng hàm IsNull để kiểm tra biến Variant có chứa Null hay không. Biến không bao giờ mang giá trị Null nếu ta không gán trực tiếp cho nó, vì vậy không cần phải dùng hàm IsNull. Nếu gán Null cho một biến không phải kiểu Variant, VB sẽ báo lỗi. - Giá trị Error: trong một biến Variant, Error là một giá trị đặc biệt thể hiện một điều kiện lỗi vừa xảy ra trong thủ tục. Tuy nhiên, không như các lỗi khác, các xử lý lỗi thông thường của ứng dụng không xảy ra. Do đó, ta có thể xử lý dựa trên các giá trị lỗi. Giá trị Error được sinh ra bằng cách chuyển đổi giá trị lỗi dùng hàm CVErr. h. Kiểu mảng Mảng là một xâu các biến có cùng tên và cùng kiểu dữ liệu. Dùng Array làm chương trình đơn giản và rút gọn, vì ta có thể dùng vòng lặp. Mảng có biên trên và biên dưới, các thành phần trong mảng là liên tục giữa 2 biên. Có 2 loại biến mảng: mảng có chiều dài cố định và mảng động có chiều dài thay đổi lúc thi hành. Mảng có chiều dài cố định có thể được khai báo Public trong ứng dụng, trong modul hoặc Private trong một thủ tục. Mảng động có thể thay đổi kích cỡ, là một trong những ưu điểm của VB, mảng động giúp quản lý bộ nhớ một cách hiệu quả. Ta có thể dùng một mảng lớn trong thời gian ngắn, sau đó xóa bỏ để trả vùng nhớ cho hệ thống. 2. Các cấu trúc điều khiển cơ bản a. Cấu trúc chọn So sánh mặc định trong VB là so sánh phân biệt cỡ chữ, nếu muốn tắt chế độ này, ta thêm dòng khai báo sau vào chương trình: Option Compare Text Nếu muốn trả về trạng thái ban đầu, có 2 cách: - Đưa vào dòng khai báo: Option Compare Binary - Chỉ cần xóa dòng khai báo “ Option Compare Text” Các biểu thức so sánh: Ký hiệu Ý nghĩa = Bằng Khác > Lớn hơn < Nhỏ hơn >= Lớn hơn hay bằng <= Nhỏ hơn hay bằng b. If…Then + Một dòng lệnh: If Then + Nhiều dòng lệnh: If Then End If Điều kiện là một so sánh hay một biểu thức mang giá trị số. VB thông dịch giá trị này thành True/ Fasle (0 là Fasle, giá trị khác 0 là True). Nếu điều kiện là True, VB thi hành tất cả các dòng lệnh sau từ khóa Then. Ví dụ: If anyDate < Now Then anyDate =now If anyDate < Now Then anyDate =now End If Lưu ý: Trường hợp một dòng lệnh không có End If c. If…Then…Else If Then [khối lệnh- 1] [Elself Then [khối lệnh- 2]… [Else [khối lệnh- n] End If VB kiểm tra điều kiện thứ nhất. Nếu nó sai, VB kiểm tra điều kiện thứ hai,…cho đến khi điều kiện đúng. VB thi hành khối lệnh tương ứng và sau đó thi hành dòng chương trình ngay sau End If. d. Select Cases Select Case [Case [khối lệnh -1]] [Case [khối lệnh -2]] .... [Case Else [khối lệnh –n]] End Select Mỗi danh sách biểu thức chứa một hoặc nhiều giá trị, các giá trị cách nhau dấu phẩy. Mỗi khối lệnh có thể chứa từ 0 đến nhiều dòng lệnh. e. Do…Loop Thi hành một khối lệnh với số lần lặp không định trước, trong đó một biểu thức điều kiện dùng so sánh để quyết định vòng lặp có tiếp tục hay không. Điều kiện phải quy về False (0) hoặc True (khác 0). Kiểu 1: Lặp trong khi điều kiện là True Do While Loop Kiểu 2: Vòng lặp luôn có ít nhất một lần thi hành khối lệnh: Do Loop While Kiểu 3: Lặp trong khi điều kiện là False: Do Until Loop Kiểu 4: Lặp trong khi điều kiện là False và có ít nhất một lần thi hành khối lệnh: Do Loop Until f. For…Next For = To [Step ] Next[] Biến đếm, điểm đầu, điểm cuối và bước nhảy là những giá trị số. Bước nhảy có thể là dương hoặc âm, nếu bước nhảy là số dương, điểm đầu phải nhỏ hơn hoặc bằng điểm cuối. Nếu không khối lệnh sẽ thi hành. Nếu bước nhảy là số âm, điểm đầu phải lớn hơn hoặc bằng điểm cuối. Nếu Step không được chỉ ra, mặc định bước nhảy là 1. g. For Each…Next Tương tự vòng lặp For…Next, nhưng nó lặp theo số phần tử của một tập các đối tượng hay một mảng thay vì theo số lần lặp xác định. Vòng lặp này tiện lợi khi ta không biết chính xác bao nhiêu phần tử trong tập hợp. For Each In Next Để dùng For Each…Next thì phần tử trong tập hợp chỉ có thể là biến Variant, biến Object, hoặc một đối tượng trong Object Browser; phần tử trong mảng chỉ có thể là biến Variant; không dùng For Each…Next với mảng chứa kiểu tự định nghĩa vì Variant không chứa kiểu tự định nghĩa. h. Vòng lặp While…Wend Tương tự vòng lặp Do…While, nhưng ta không thể thoát vòng lặp bằng lệnh Exit. Vì vậy, vòng lặp kiểu này chỉ thoát khi biểu thức điều kiện sai. While sPassword “ Enter password” sPassword = InputBoxs(“Enter password”) Wend i. Câu lệnh Go To Được dùng cho bẫy lỗi. On Error Go To ErrorHandler 3.2. Cơ sở dữ liệu trên ACCESS Bảng Nhân viên: Lưu trữ tất cả thông tin về lý lịch của nhân viên như họ tên, ngày sinh, giới tính, địa chỉ, trình độ chuyên môn.... Khóa chính là MaxNV, mỗi một nhân viên chi được xác định bởi 1 MaxNV này nên trách được sự lặp lại hai hay nhiều nhân viên trùng nhau do nhầm lẫn trong khi cập nhật thông tin. Bảng Chức vụ: Gồm có Mã chức vụ, Tên chức vụ và Mã Đối tượng. Khóa chính là MaxCV, Tên chức vụ cho biết tên của các chức vụ hiện có tong cơ quan như: Giám đốc, phó Giám đốc, Tưởng phòng, Phó phòng hay Nhân viên. Trường MaxDT cho biết Chức vụ đó thuộc nhóm đối tượng nào, là Lao động gián tiếp hay trực tiếp, lao động hợp đồng, thử việc hay Cộng tác viên. Các thông tin về đối tượng đó được lưu trữ trong bảng Đối Tượng LĐ. Bảng Đối tượng: Khóa chính là MaxDT xác định duy nhất một nhóm đối trượng. Tên đối tượng gồm có: LĐ gián tiếp(Ban Giám đốc), LĐ trực tiếp, LĐ dài hạn, LĐ ngắn hạn, Thử việc và Cộng tác viên Bảng Khen thưởng - Kỷ luật: Lưu trữ thông tin về quá trình khen thưởng cũng như kỷ luật của nhân viên như Ngày tháng được khen thương hay kỷ luật, hình thức và mức độ khen thưởng hay kỷ luật. Khóa chính là MãNV. Bảng Phòng ban: Gồm Mã phòng ban, Tên phòng ban và Mã khối. khóa chính là MaxPB xác định duy nhất một tên phòng ban trong cơ quan. Hiện Ngân hàng CSXH Thanh Hóa có 15 phòng ban như sau: QHKH cá nhân, QHKH doanh nghiệp, QH định chế tài chính, Kế hoạch, Tín dụng - Đầu tư, Kế toán tài chính, Quản lý rủi do, DVKH cá nhân, DVKH tô chức, Xử lý bộ chứng từ, Ngân quỹ, Hành chính, Nhân sự, Pháp chế và Công nghệ thông tin. Mã khối xác định phòng ban đó thuộc khối hoạt động nào. Có 4 khối hoạt động được lưu trong bảng Khối như sau: Khối QHKH, Khối tông hợp, Khối tác nghiệp và khối hỗ trợ kỹ thuật. Bảng Khối: Gồm có Mã khối và tên khối. bang này lưu trữ thông tin về các khối hoạt động trong Ngân hàng như Khối QHKH, Khối tông hợp, Khối tác nghiệp và khối hỗ trợ kỹ thuật. khóa chính là Mã khối. Bảng Lương: lưu thông tin về Lương hàng tháng của nhân viên vì vậy khóa chính gồm MaxNV và Tháng. Gồm có các trường lưu thông tin dùng để tính lương như Lương cơ bản, HS lương, HS bao hiêm, Thưởng, Tạm ứng, Hỗ trợ và Khấu trừ. Khoản khấu trừ là tổng của các khoản Thuế hay bảo hiểm nhân viên phải đóng( thuế TNCN, bao hiểm XH, bảo hiểm y tế, bảo hiểm thất nghiệp). Lương thực lĩnh = LươngCB*HS lương*HS Bảo hiểm + Thưởng - Khấu trừ. Bảng Chấm công: Lưu thông tin về các ngày công trong 1 tháng gồm có Ngày bình thường, Ngày chủ nhật, Ngày lễ, Nghỉ phép. 2 Khóa chính là MaxNV và Tháng chấm công. Ngày công đi làm= ngày bình thường + 1.5*(Chủ nhật + Ngày lễ) Bảng Trình độ văn hóa: Lưu thông tin về trình độ văn hóa của từng nhân viên. Gồm Mã tình độ và Tên trình độ, khóa chính là Mã tình độ. Tên trình độ văn hóa gốm có: Đại học, Trên đại học, Cao đẳng, Trung cấp, Phổ thông. Bảng Liên Kết Thực Thể : Mối quan hệ gữa các bảng được thể hiện trong bảng này. 3.3. Thiết kế các FORM chương trình 3.3.1. Các chức năng của hệ thống: Hệ thống : + Đăng nhập + Đổi mật khẩu + Thông tin người dùng + Trợ giúp + Thoát Cập nhật: + Cập nhật hồ sơ nhân viên + Cập nhật phòng ban + Cập nhật khối điều hành + Cập nhật chức vụ + Cập nhật đối tượng lao động + Cập nhật trình độ văn hóa + Cập nhật bảng chấm công + Cập nhật quá trình lương + Cập nhật khen thưởng, kỷ luật Tìm kiếm : + Theo họ tên + Theo phòng ban + Theo chức vụ + Theo trình độ văn hóa + Theo đối tượng lao động Thống kê, báo cáo : + Danh sách lao động: Theo chức vụ Theo phòng ban Theo trình độ văn hóa Theo hệ số lương + Phòng ban + Khen thưởng, kỷ luật: Khen thưởng Kỷ luật + Khối điều hành + Lương nhân viên: Bảng chấm công Lương thực lĩnh Khoản hỗ trợ Khoản tạm ứng Ngoài ra còn có chức năng KHÓA HỆ THỐNG dùng để đăng xuất khỏi hệ thống khi không làm việc. 3.3.2. Các vấn đề đã thực hiện được của chương trình: Cập nhật: - Chương trình cho phép nhập thêm các thông tin mới như Hồ sơ nhân viên, thông tin phòng ban, chức vụ, khen thưởng kỷ luật, bảng chấm công hay quá trình lương của nhân . Với điều kiện là không được trùng khóa chính (chương trình sẽ tự động kiểm tra mỗi khi người sử dụng nhập vào một bản ghi mới để tránh việc nhập sai chương trình sẽ báo lỗi khi nhập trùng khóa hay nhập không hợp lệ và bắt phải nhập lại cho đến khi hợp lệ). Chỉnh sửa, xóa: Khi những thụng tin về nhân viên vì một lý do nào đó trong quá trình làm việc có thể bị thay đổi như quê quán, địa chỉ, ngày vào Đảng v.v… người dùng sẽ sử dụng chức năng này để cập nhật những thông tin mới nhất về họ. Thông tin hiện lên bao gồm toàn bộ các mục như trong hồ sơ sinh viên, những thông tin này cho phép thay đổi, cập nhật mới. Những thông tin mới sẽ được ghi lại và tra cứu về sau. Chức năng chỉnh sửa được thiết kế ở các form nhập, để tiện cho việc sửa những thông tin mà người sử dụng cần thay đổi. Người sử dụng có thể dùng chức năng xóa để xóa các thông tin nếu muốn, chương trình sẽ tự động loại những thông tin bị xóa ra khỏi cơ sở dữ liệu. Tra cứu: Chương trình cho phép tra cứu nhân viên theo tên, theo họ đệm theo hồ sơ nhân viên, tên phòng ban, tên chức vụ . Ngoài ra cũng cho phép người sử dụng tìm kiếm theo đối tượng lao động hay trình độ văn . Chức năng này tương tự chức năng cập nhật chỉ khác là không cho phép thay đổi cập nhật mà chỉ cho phép xem thông tin của kết quả tìm kiếm. Thống kê: Chương trình cho phép in ra các báo cáo về hồ sơ nhân viên được phân chia theo chức vụ , theo phòng ban, theo trình độ văn hóa và theo hệ số lương. In ra được các báo cáo chấm công, bảng lương, các khoản hỗ trợ, các khoản tạm ứng theo từng tháng do người dùng lựa chọn. 3.3.3. Giới thiệu một số Form chính của chương trình: Form MAIN: Form chính khi khởi động chương trình, gồm một MEMU cho phép người dùng lựa chọn các chức năng trong đó. Lưu ý là trước khi sử dụng được các chức năng người sử dụng cần Đăng nhập trước Form đăng nhập: Đây là phần mang tính chất bảo mật của hệ thống để tránh được sự truy cập bất hợp pháp hay truy cập với các mục đích xấu. Để sử dụng được các chức năng của hệ thống người dùng cần phải đăng nhập đúng Tài khoản và mật khẩu của minh. Đối với nhân viên thì được cung cấp tài khoản truy cập hệ thống để thực hiện một số hoạt động cho phép như Thêm một thông tin , chỉnh sửa thông tin của mình hay thêm quá trình khen thưởng kỷ luật của một nhân viên... Còn đối với người quan lý cấp cao hơn thì tài khoản sẽ có toàn quyền xử lý như Thêm, Sửa, Xóa thông tin. Khi người dùng quên mật khẩu có thế nhấn vào dòng chữ Quên mật khâu để có thể lấy lại mật khẩu nhanh chóng, tuy nhiên khi sử dụng trong thực tế cầ cung cấp một số thông tin cá nhân mới có thể lấy lại mật khẩu. Nút Đăng ký cho phép tạo một tài khoản mới để đăng nhập và sử dụng chương trình. Khi đưa vào sử dụng thực tế thì những tài khoản đăng ký bởi người dùng thì chỉ được phép Đăng nhập để xem ngoài ra không được thực hiện bất cứ quyền nào khác. Form cập nhật hồ sơ nhân viên: Các chức năng Thêm, Sưa , Xóa hồ sơ nhân viên. Trong trường hợp có một nhân viên mới người quản trị sẽ phải Thêm mới thông tin của nhân viên này và cập nhật vào Cơ sở dữ liệu. hoặc khi thông tin của nhân viên bị sai lệch thì có thể chinh sửa hay xóa thông tin Form cập nhật phòng ban: Form này giúp người quản trị có thể Thêm, Sửa , Xóa thông tin về phòng ban mỗi khi có sự thay đổi trong thực tế. Trường Mã phòng ban là khóa chính trong Cơ sở dữ liệu nên không được để trống hay trùng với mã đã có, nếu nhập trùng hay bỏ trống hệ thống sẽ thông báo và bắt nhập lại. Cập nhật chức vụ: Tương tự như cập nhật phòng ban, Form này cho phép cập nhật thông tin của các chức vụ trong cơ quan. Mã chức vụ không được phép bỏ trống hay nhập trùng mã. Form cập nhật bảng chấm công: Form này để cập nhật quá trình chấm công đi làm của nhân viên. Trước tiên nhấn nút cập nhật sau đó chọn mã nhân viên và chọn tháng cần cập nhật. Nếu trong tháng đó nhân viên đã được cập nhật rồi thì hệ thống sẽ thông báo và yêu cầu cập nhật tháng khác. Khi người dùng nhấn vào Xem hết thì kết quả hiện ra là tất cả các nhân viên đã được chấm công theo tháng, nhìn vào thông tin này người dùng biết được tháng nào nhân viên nào chưa được chấm công và có thê cập nhật lại. Form cập nhật quá trình lương: Các chức năng gồm có Thêm, Sửa, Xóa. Khóa để xác định một bản ghi trong cơ sở dữ liệu là Mã nhân viên và Tháng vì vậy khi cập nhật quá trình lương nếu nhập cho Nhân viên đã có bảng lương tháng rồi thì chương trình sẽ thông báo nhập sai và bắt nhập lại cho tháng khác hoặc hủy bo việc nhập. một lưu ý quan trọng nữa là các trường như Lương, Thưởng, HS lương, HS bao hiểm, Khấu trừ, Tạm ứng, Hỗ trợ thì dữ liệu nhập vào bắt buộc phải là số nguyên, với các trường Hệ số thì có thể là số thực, nếu nhập sai hệ thống sẽ thông báo lỗi cho tới khi nhập đúng mới thôi. Form cập nhật khen thương - kỷ luật: Khi có nhân viên được khen thưởng hay bị kỷ luật thì người dùng phải cập nhật vào cơ sở dữ liệu bằng cách Thêm mới một bản ghi tong Form này. Với một nhân viên thì trong 1 ngày chỉ có thể có 1 hình thức là khen thưởng hay kỷ luật và không thể có 2 lần khen thương hay kỷ luật trong cùng 1 ngày được. Khi muốn điều chỉnh thông tin khen thương ky luật thì người dùng có thể Sửa và lưu ý là chỉ được sửa hai trường đó là Hình thức và Mức độ. Khi nhân viên hết thời hạn ky luật người quan trị nhân vào nút Xóa để hủy bỏ kỷ luật với nhân viên đó. Form tìm kiếm theo họ tên nhân viên: Form này giúp tra cứu các thông tin của một hay nhiều nhân viên do người dùng muốn, chỉ cần nhập họ tên chính xác vào ô nhập và nhấn nút tìm kiếm sẽ hiện kết quả như mong muốn. hoặc có thể tìm kiếm tương đối nếu như người dùng chỉ nhập tên hoặc tên dệm hoặc họ của nhân viên. Ví dụ muốn tra cứu thông tin của tất cả các nhân viên họ Nguyễn thì người dùng chỉ cần nhập " Nguyen" vào ô nhập tên và nhấn nút Tìm kiếm, kết quả hiện ra là thông tin của tất cả các nhân viên có họ Nguyễn trong cơ quan Form tìm kiếm theo tên phòng ban: Tương tự như tìm kiếm theo tên nhân viên khi muốn tìm kiếm các nhân viên thuộc một phòng ban nào đó thì sử dụng chọn Form này Form tìm kiếm theo tên chức vụ: Giúp người sử dụng tra cứu thông tin của các nhân viên có cùng một chức vụ Form tìm kiếm theo trình độ văn hóa: Cũng tương tự Form này cho phép tìm kiếm thông tin của các nhân viên có cùng trình độ văn hóa Form tìm kiếm theo đối tượng lao động: Tương tự Form này để tra cứu thông tin nhân viên thuộc cùng một đối tượng lao động Form Báo cáo Danh sách lao động được khen thưởng: Khi người dùng muốn in ra danh sách các nhân viên được khen thưởng có thể chọn vào Menu THỐNG KÊ BÁO CÁO->Khen thưởng kỷ luật ->Khen thưởng Form Báo cáo Danh sách lao động bị kỷ luật:Tương tự khi người dùng muốn in ra danh sách nhân viên bị kỷ luật Form Báo cáo Danh sách lao động theo khối: In ra danh sách các nhân viên thuộc một khối nhất định Form Báo cáo Bảng chấm công tổng hợp: In ra tất cả các thông tin về ngày công của tất cả các nhân viên Form Báo cáo Bảng lương tổng hợp: Tương tự sẽ in ra thông tin về Lương của tất cả các nhân viên Báo cáo chấm công: Form này giúp người sử dụng lựa chọn tháng cần in ra báo cáo chấm công bằng cách chọn tháng cần in hoặc có thể in hết mà không cần chọn tháng Bảng chấm công theo tháng: Khi người dùng chọn tháng cần in và nhân nút IN trong Fom báo cáo châm công sẽ in ra chi tiết các ngày công của các nhân viên trong Tháng được chọn Báo cáo Lương: Form này giúp người sử dụng lựa chọn tháng cần in ra báo cáo Lương bằng cách chọn tháng cần in hoặc có thể in hết mà không cần chọn tháng Bảng lương theo tháng: Khi người dùng chọn tháng cần in và nhân nút IN trong Fom báo cáo Lương sẽ in ra chi tiết Lương của các nhân viên trong Tháng được chọn Form Trợ giúp: Chứa các thông tin hướng dẫn sử dụng người dùng về cách đăng nhập hệ thống hay cách cài đặt Font khi không hiển thị được Font tiếng Việt. PHỤ LỤC: MÃ NGUỒN CỦA MỘT SỐ FORM CHÍNH 1. Mã nguồn Form Cập nhật: Dưới đây là mã nguồn của Form Cập nhật hồ sơ nhân viên, nhìn chung tất cả các Form cập nhật đều phải có các chức năng như Thêm, Sửa, Xóa. Vì vậy các thủ tục Thêm(), Sửa(), Xóa() của các Form tương tự như nhau. Dim conn As ADODB.Connection Dim strconn As String Dim rs As ADODB.Recordset Dim strsql As String Dim addnewflag, b As Boolean ' Biến này có giá trị True khi nhấn nút Thêm mới Private Sub Form_Load() Me.Command6.Enabled = True Me.l3.Visible = False addnewflag = False 'Giá tị mặc định của biến này là False Setbuttons (False) lockedControls (True) End Sub Private Sub Setbuttons(bval As Boolean) cmddongy.Enabled = bval cmdhuybo.Enabled = bval cmdnoicap.Enabled = bval cmdselectcv.Enabled = bval cmdselectpb.Enabled = bval cmdselecttd.Enabled = bval cmdthem.Enabled = Not bval cmdsua.Enabled = Not bval cmdxoa.Enabled = Not bval End Sub Private Sub lockedControls(bval As Boolean) txtmanv.Locked = bval txthoten.Locked = bval txtngaysinh.Locked = bval txtgioitinh.Locked = bval txtsocmt.Locked = bval txtngaycap.Locked = bval txtnoicap.Locked = bval txtngayvaodang.Locked = bval txthotenbo.Locked = bval txtnghenghiepbo.Locked = bval txthotenme.Locked = bval txtnghenghiepme.Locked = bval txthktt.Locked = bval txtnguyenquan.Locked = bval txtchuyenmon.Locked = bval txttencv.Locked = bval txttenpb.Locked = bval txttentd.Locked = bval End Sub Private Sub clearall() txtmanv.Text = "" txthoten.Text = "" txtngaysinh.Text = "" txtgioitinh.Text = "" txtchuyenmon.Text = "" txtngayvaodang.Text = "" txtnguyenquan.Text = "" txthktt.Text = "" txtsocmt.Text = "" txtngaycap.Text = "" txtnoicap.Text = "" txthotenbo.Text = "" txtnghenghiepbo.Text = "" txthotenme.Text = "" txtnghenghiepme.Text = "" txttenpb.Text = "" txttencv.Text = "" txttentd.Text = "" End Sub Private Sub cmdthem_click() addnewflag = True Adodc1.Recordset.AddNew clearall Setbuttons (True) lockedControls (False) Me.cmdhuybo.Enabled = False Me.l3.Visible = True Me.Command1.Enabled = False Me.Command2.Enabled = False Me.Command3.Enabled = False Me.Command4.Enabled = False Me.Command6.Enabled = False End Sub Private Sub cmdsua_click() addnewflag = False Setbuttons (True) lockedControls (False) Me.txtmanv.Locked = True Me.l3.Visible = False End Sub Private Sub cmddongy_Click() If addnewflag = True Then Set rs = New ADODB.Recordset Set conn = New ADODB.Connection strconn = "provider=microsoft.jet.oledb.4.0;data source= " & App.Path & "\qlns.mdb" conn.CursorLocation = adUseClient conn.Open strconn strsql = "select * from nhanvien, chucvu, phongban,trinhdovh where nhanvien.macv=chucvu.macv and nhanvien.mapb=phongban.mapb and nhanvien.matd=trinhdovh.matd and nhanvien.manv='" & Me.txtmanv & "'" rs.Open strsql, conn If Not rs.EOF Then MsgBox "Ban nhap trung ma nhan vien!", vbOKOnly + vbInformation, "Thong Bao" Setbuttons (True) lockedControls (False) Else If txtmanv.Text = "" Then MsgBox "Ban chua nhap ma nhan vien!", vbOKOnly + vbInformation, "Thong Bao" Exit Sub Setbuttons (True) lockedControls (False) Else Adodc1.Recordset.Fields("manv") = txtmanv.Text If txthoten.Text "" Then Adodc1.Recordset.Fields("hoten") = txthoten.Text Else MsgBox "Ban chua nhap ho ten" Exit Sub Setbuttons (True) lockedControls (False) End If If txttencv.Text "" Then Adodc1.Recordset.Fields("macv") = txttencv.Text Else MsgBox "Ban chua chon Chuc vu..." Exit Sub Setbuttons (True) lockedControls (False) End If If txttenpb.Text "" Then Adodc1.Recordset.Fields("mapb") = txttenpb.Text Else MsgBox "Ban chua chon Phong ban..." Exit Sub Setbuttons (True) lockedControls (False) End If If txttentd.Text "" Then Adodc1.Recordset.Fields("matd") = txttentd.Text Else MsgBox "Ban chua chon Trinh do van hoa..." Exit Sub Setbuttons (True) lockedControls (False) End If If txtngaysinh.Text "" Then Adodc1.Recordset.Fields("ngaysinh") = txtngaysinh.Text End If If txtgioitinh.Text "" Then Adodc1.Recordset.Fields("gioitinh") = txtgioitinh.Text End If If txtchuyenmon.Text "" Then Adodc1.Recordset.Fields("chuyenmon") = txtchuyenmon.Text End If If txtngayvaodang.Text "" Then Adodc1.Recordset.Fields("ngayvaodang") = txtngayvaodang.Text End If If txtnguyenquan.Text "" Then Adodc1.Recordset.Fields("nguyenquan") = txtnguyenquan.Text End If If txthktt.Text "" Then Adodc1.Recordset.Fields("hokhauthuongtru") = txthktt.Text End If If txtsocmt.Text "" Then Adodc1.Recordset.Fields("socmtnd") = txtsocmt.Text End If If IsNumeric(Me.txtsocmt.Text) = False Then MsgBox "Nhap lai so CMT..." Exit Sub Setbuttons (True) lockedControls (False) Else If txtngaycap.Text "" Then Adodc1.Recordset.Fields("ngaycap") = txtngaycap.Text End If If txtnoicap.Text "" Then Adodc1.Recordset.Fields("noicap") = txtnoicap.Text End If If txthotenbo.Text "" Then Adodc1.Recordset.Fields("hotenbo") = txthotenbo.Text End If If txtnghenghiepbo.Text "" Then Adodc1.Recordset.Fields("nghenghiepbo") = txtnghenghiepbo.Text End If If txthotenme.Text "" Then Adodc1.Recordset.Fields("hotenme") = txthotenme.Text End If If txtnghenghiepme.Text "" Then Adodc1.Recordset.Fields("nghenghiepme") = txtnghenghiepme.Text End If MsgBox " Ban da them 1 ban ghi moi..." Setbuttons (False) lockedControls (True) Adodc1.Recordset.Update End If End If End If End If Setbuttons (False) lockedControls (True) Adodc1.Recordset.Update End Sub Private Sub cmdhuybo_click() addnewflag = False If addnewflag = False Then Adodc1.Recordset.CancelUpdate End If lockedControls (True) Setbuttons (False) Me.Command1.Enabled = True Me.Command2.Enabled = True Me.Command3.Enabled = True Me.Command4.Enabled = True Me.Command6.Enabled = True End Sub Private Sub cmdxoa_click() addnewflag = False On Error GoTo deleteerr If (Adodc1.Recordset.BOF = False And Adodc1.Recordset.EOF = False) Then returnvalue = MsgBox(" Ban muon xoa ban ghi nay ? ", vbOKCancel + vbQuestion, "Notice") If returnvalue = vbOK Then Adodc1.Recordset.Delete Adodc1.Recordset.MoveNext If Adodc1.Recordset.EOF Then Adodc1.Recordset.MoveLast End If Exit Sub End If deleteerr: MsgBox Err.Description End Sub Private Sub form_unload(cancel As Integer) addnewflag = False End Sub 2. Mã nguồn Form Tìm kiếm: Dim conn As ADODB.Connection Dim rs As ADODB.Recordset Dim strconn As String Private Sub cmdtimkiem_Click() Dim strsql As String Dim strhoten As String Set rs = New ADODB.Recordset Set conn = New ADODB.Connection strconn = "provider=microsoft.jet.oledb.4.0;data source=" & App.Path & "\qlns.mdb" conn.CursorLocation = adUseClient conn.Open strconn strhoten = Trim(Me.txthoten.Text) If strhoten "" Then strsql = "SELECT nhanvien.manv,nhanvien.hoten,phongban.tenpb,chucvu.tencv,nhanvien.gioitinh,nhanvien.ngaysinh,nhanvien.chuyenmon,nhanvien.hokhauthuongtru from nhanvien,phongban,chucvu where nhanvien.mapb=phongban.mapb and nhanvien.macv=chucvu.macv and nhanvien.hoten like '%" & strhoten & "%'" rs.Open strsql, conn, 1, 3 Set Me.grid.DataSource = rs Else MsgBox "Ban chua nhap ten can tim !" Exit Sub End If End Sub Private Sub txthoten_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then Me.cmdtimkiem.SetFocus End If End Sub Private Sub CmdExit_Click() Unload Me End Sub KẾT LUẬN Sau khi hoàn thành đề tài này em thấy ngôn ngữ Visual Basic 6.0 có các ứng dụng thực tiễn cao, giúp chúng ta có thể xây dựng được các Hệ thống quản lý áp dụng cho các trường học, các doanh nghiệp, bệnh viện, khách sạn…. Là một sinh viên đang học Công nghệ thông tin, việc học tập, trang bị và tiếp thu các kiến thức về tin học từ thực tế cũng như tìm hiểu về công tác quản lý là điều cần thiết. Khi làm các bài tập Quản lý cơ sở dữ liệu đã giúp em có cơ hội vận dụng kiến thức vừa học được vào thực tế. Dưới sự hướng dẫn của cô giáo em đã tìm hiểu về Visual Basic - một phần mềm quản lý và hoàn thành bài báo cáo đó là tạo các form, liên kết các form, nhập dữ liệu cho bảng, tạo ra các liên kết cơ sở dữ liệu cho các bảng,… rồi từ đó tạo các Menu giao diện cho chương trình. Chương trình thực hiện một số chức năng về việc cập nhật cơ sở dữ liệu như: thêm, sửa, xoá, . Sau khi làm xong bài báo cáo này em đã có thêm những kinh nghiệm về xây dựng và thiết kế một bài toán quản lý. Trong khi làm bài chắc chắn sẽ có nhiều thiếu sót, chưa hoàn thiện và chưa đáp ứng nhu cầu thực tế đòi hỏi thì em rất mong sự đóng góp ý kiến của cô giáo và các bạn để em có thể làm tốt hơn và phát triển những ứng dụng của mình sau này. Một lần nữa em xin cảm ơn cô giáo và các bạn! Thái nguyên, Tháng 05 năm 2011 Sinh Viên Trần Thị Thu Hương TÀI LIỆU THAM KHẢO Nguyễn Văn Ba, Phân tích và thiết kế hệ thống thông tin, NXB ĐHQG HN, 2000 Microsoft Visual Basic & Lập trình cơ sở dữ liệu 6.0, NXB Lao động – xã hội Lập trình Visual Basic 6.0, NXB trẻ Elicom, Microsoft Office 2000 thông qua hình ảnh, NXB THỐNG KÊ NHẬN XÉT CỦA GIÁO VIÊN ……………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………… Giáo viên hướng dẫn: Nguyễn Thị Tuyển

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

  • docLy thuyet.doc
  • rarChuong trinh.rar