Mục đích của việc thiết kế kiểm soát là để hệ thống hoạt động đúng đắn, hiệu quả, tăng độ tin cậy của thông tin hệ thống, phòng tránh hay hạn chế tối đa các nguy cơ gây mất mát, hư hỏng thông tin gây đe dọa sự hoạt động của hệ thống do ngẫu nhiên hay cố ý.
Mục đích của hệ thống cũng là đề xuất các biện pháp nhằm làm cho hệ thống đảm bảo được.
Các khía cạnh cần quan tâm của thiết kế kiểm soát là: tính chính xác, tính an toàn, tính bảo mật, tính riêng tư.
104 trang |
Chia sẻ: aloso | Lượt xem: 1803 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Đề tài Xây dựng Website quản lý nhân sự cho công ty INTECH, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ẽ tìm hàm có cùng tên với giá trị biến đó và thực hiện.
2.4.2.9. Các toán tử
PHP có các toán tử cho các phép số học: + - * / %
Các toán tử logic: And, Or, Xor ! && ||
Toán tử thao tác với bit: & | ^ ~ >
Toán tử so sánh: = =,!=, , =,= = = = (bằng và cùng kiểu - Chỉ có trong PHP4), != = (khác hoặc khác kiểu - Chỉ có trong PHP 4).
Toán tử điều khiển lỗi: @ - Khi đứng trước 1 biểu thức thì các lỗi của biểu thức sẽ bị bỏ qua và lưu trong $php_errormsg.
2.4.2.10. Lớp và đối tượng
Lớp có thể được mở rộng bằng những lớp khác. Lớp mới thu được có tất cả những biến và hàm của các lớp thành phần.
Tuy nhiên, các hàm khởi tạo của lớp cha sẽ không được gọi khi hàm khởi tạo của lớp con được gọi. Hàm khởi tạo có thể có đối số hoặc không.
2.4.2.11. Tham chiếu
Tham chiếu trong PHP có nghĩa là lấy cùng một giá trị bằng nhiều tên biến khác nhau. Khác với con trỏ C, tham chiếu là một bảng các bí danh.
2.4.2.12. Thao tác với ảnh
Có thể dùng PHP để tạo và thao tác với các file ảnh có định dạng khác nhau, bao gồm: .gif,.jpg,.bmp...PHP có thể đưa các file ảnh trực tiếp đến các trình duyệt.
2.4.3. MySQL
2.4.3.1 My SQL là gì?
MySQL là một database server, là hệ thống quản lý cơ sở dữ liệu quan hệ. Trong việc lưu trữ, tìm kiếm, sắp xếp và truy vấn dữ liệu, nó tỏ ra rất nhanh và mạnh mẽ. MySQL thường được sử dụng chung với PHP trong những trang Web cần sử dụng tới CSDL.
2.4.3.2. Cài đặt MySQL
Download MySQL từ địa chỉ
Sau khi download xong, giải nén và tiến hành cài đặt.
Phải thiết lập Username (admin) và database server (localhost).
2.4.3.3. Sơ lược MySQL
Các lệnh trong SQL được kết thúc bởi dấu chấm phảy (;). Trừ một số trường hợp như lệnh quit là trường hợp đặc biệt.
MySQL đưa ra kết quả dưới dạng một bảng (table) gồm các cột (columns) và các hàng (rows).
2.4.3.4. Các lệnh cơ bản trong MySQL
* SHOW DATABASE; // Liệt kê tất cả các database có trên server.
* USE tên database ; // Lựa chọn sử dụng database có trên server, nếu có máy sẽ báo là database changed.
* CREATE DATABASE tên database; // Tạo database mới.
* SHOW TABLE; // Liệt kê các bảng trong database.
* CREATE TABLE tên table; // tạo bảng cho database.
* DESCRIBE tên table;// mô tả bảng đã tạo.
* INSERT INTO tên table [COLUMN 1, COLUMN 2,...] VALUES (VALUES 1, VALUES 2,..); // Đưa dữ liệu vào bảng.
* SELECT items
FROM table
[WHERE điều kiện]
[GROUP BY group_type]
[HAVING where_ definition]
[ORDER BY order_type]
[LIMIT limit_criteria]
// Truy vấn CSDL trong các bảng
* LOAD DATA INFILE “tenfile.exception” INTO TABLE tên table;
//Nhập dữ liệu vào bảng từ trình soạn thảo văn bản khác
* DELETE FROM table
[WHERE condition]
[LIMIT number]
// Xoá dữ liệu trong bảng.
*. UPDATE table name
SET column1= expression 1, column 2= expression 2,...
[WHERE condition]
[LIMIT number]
* ALTER TABLE tên table RENAME tên table mới; // Thay đổi tên bảng.
m. ALTER TABLE table_name ADD COLUMN column_name, column attribute
// Thêm cột vào bảng.
* ALTER TABLE table_name DROP COLUMN column_name
// Xoá cột trong bảng.
2.4.3.5. Các kiểu dữ liệu trong MySQL
* Kiểu ký tự
Kiểu char
Kiểu text
Kiểu Enum
* Kiểu số
Kiểu int/integer
Kiểu Tinyint
Kiểu Mediumint
Kiểu bigint
* Kiểu Date/ Time
Kiểu Date
Kiểu datetime
Kiểu timestamp
Kiểu time
Kiểu year
2.4.4. Giới thiệu công cụ Crystal Report
2.4.4.1. Tổng quan về Crystal Report
Reports là các báo cáo có thể truy xuất và định dạng thông tin hiển thị của dữ liệu từ các nguồn dữ liệu khác nhau như cơ sở dữ liệu hoặc file …
Điểm khác nhau cơ bản nhất của report và form đó là: form dùng để hiển thị và cập nhật thông tin, report dùng để hiển thị và định dạng thông tin và có chức năng in ra giấy.
Phiên bản mới nhất là Crystal Report XI – Release 2.
Phiên bản đi kèm với Visual Studio .NET 2003 là Crytal Report 9
Phiên bản đi kèm với Visual Studio .NET 2005 là Crystal Report 10
Có thể vào site để tham khảo thêm.
2.4.4.2. Giới thiệu về Crystal Report 9
Crystal Reports 9 đã tích hợp sẵn Report Designer trong bộ Visual Studio .NET để có thể thiết kế report (có phần mở rộng là *. rpt).
Có thể tích hợp file có phần mở rộng là *. rpt vào ứng dụng Windows hoặc ứng dụng trên Web (Web application) để hiển thị các mẫu biểu báo cáo.
Việc chạy các ứng dụng có tích hợp Crystal Report đòi hỏi phải có Crystal Report Engine được cài đặt trên máy.
Làm việc dễ dàng với Unicode.
Ưu điểm:
Tích hợp chung với Visual Studio .NET.
Tạo báo cáo có thể hiển thị trên cả hai môi trường Winform và Webform.
Dễ dàng triển khai, có thể sử dụng các mođun tích hợp để tạo file cài đặt.
Sử dụng kiến trúc ADO.NET để kết nối CSDL nhanh hơn.
Có khả năng tạo các báo cáo dịch vụ Web
Cài đặt:
Có thể cài đặt chung với bộ Visual Stdio.NET.
Có thể cài riêng bản Developer.
CHƯƠNG 3: PHÂN TÍCH HỆ THỐNG
3.1. BIỂU ĐỒ PHÂN CẤP CHỨC NĂNG
Hệ thống được phân cấp thành các chức năng như hình dưới đây. Mục tiêu của biểu đồ là cung cấp cách nhìn tổng quan về hệ thống.
3.1.1. Biểu đồ phân cấp chức năng của hệ thống
Hình 3.1: Biểu đồ phân cấp chức năng của hệ thống
3.1.2. Mô tả các chức năng
Chức năng Hệ thống: bao gồm chức năng đổi mật khẩu, quản trị người dùng, cập nhật danh mục từ điển (chức vụ, phòng ban, chuyên ngành, loại hợp đồng). Người dùng có một tài khoản để truy nhập vào hệ thống. Sau khi đăng nhập thì họ có thể thay đổi mật khẩu của mình. Tuy nhiên, để có thể thực hiện các chức năng khác của chương trình thì cần có sự phân quyền từ phía ban quản trị. Cụ thể là mỗi một nhân viên sẽ có một mã, ứng với mỗi nhân viên sẽ có một mã chức vụ, mỗi chức vụ sẽ có các quyền khác nhau. Dựa vào quyền này sẽ áp dụng vào cụ thể cho từng chức năng của hệ thống.
Chức năng Nhân sự: bao gồm việc cập nhật hồ sơ nhân sự (cập nhật các thông tin chung như tên, tuổi, quê quán... và các thông tin khác như: hợp đồng lao động, quá trình công tác, khen thưởng- kỷ luật, bằng cấp của nhân viên), tìm kiếm nhân viên theo một hay nhiều tiêu chí nào đó, quản lý nhân viên theo phòng ban (số lượng nhân viên trong từng phòng ban) để từ đó giúp các nhà quản lý có các biện pháp điều chỉnh cho phù hợp theo yêu cầu thực tế.
Chức năng Báo cáo: bao gồm các chức năng lập báo cáo theo chức vụ, phòng ban, hợp đồng, bằng cấp, khen thưởng/ kỷ luật, nhân viên nào thay đổi công tác để từ đó có các chiến lược đúng đắn.
3.2. BIỂU ĐỒ LUỒNG DỮ LIỆU
3.2.1. Các ký hiệu quy ước sử dụng trong biểu đồ luồng dữ liệu
Chức năng
Luồng dữ liệu
Kho dữ liệu
Tác nhân ngoài
Tác nhân trong
Định nghĩa
Nhiệm vụ xử lý thông tin
Thông tin vào / ra một chức năng xử lý
Nơi lưu trữ thông tin trong một thời gian
Người hay tổ chức ngoài hệ thống có giao tiếp với hệ thống
Một chức năng hay một hệ con của hệ thống nhưng được mô tả ở trang khác
Tên đi kèm
Động từ(+ bổ ngữ)
Danh từ(+ tính từ)
Danh từ(+ tính từ)
Danh từ
Động từ
Tên
Tên
Tên
Tên
Tên
Biểu đồ
Thanh toán
Hoá đơn đã
xác nhận chi
Ví dụ
Làm đơn đặt hàng
Đơn hàng
Nhà cung cấp
Bảng 3.1: Các ký hiệu quy ước sử dụng trong biểu đồ luồng dữ liệu
Dựa vào biểu đồ phân cấp chức năng ở trên, ta có các biểu đồ luồng dữ liệu mức khung cảnh, mức đỉnh, mức dưới đỉnh như sau:
3.2.2. Biểu đồ luồng dữ liệu mức khung cảnh
Hình 3.2: Biểu đồ luồng dữ liệu mức khung cảnh
Đặc tả chức năng “Hệ thống quản lý nhân sự”
Đầu đề:
Tên chức năng: Hệ thống quản lý nhân sự.
Đầu vào: danh sách báo cáo, mật khẩu thay đổi, tìm kiếm/ cập nhật nhân sự, thông tin nhân viên, mật khẩu thay đổi.
Đầu ra: thông tin đổi mật khẩu, thông tin nhân viên, kết quả tìm kiếm/ cập nhật nhân sự, các báo cáo theo yêu cầu.
Thân:
Khi nhân viên đăng nhập vào hệ thống thì có thể đổi mật khẩu. Hệ thống sẽ gửi lại cho nhân viên các thông tin để có thể tiến hành đổi được mật khẩu.
Các nhà quản lý khi đăng nhập vào hệ thống cũng có thể đổi mật khẩu. Hệ thống sẽ gửi các thông tin mà nhà quản lý cần cung cấp để đổi được mật khẩu. Khi các nhà quản lý có yêu cầu xem danh sách các báo cáo thì hệ thống cũng sẽ gửi lại các báo cáo theo đúng yêu cầu. Nhà quản lý có nhu cầu tìm kiếm hoặc cập nhật thông tin nhân viên thì hệ thống sẽ đưa ra kết quả tương ứng phù hợp với yêu cầu đó của nhà quản lý.
3.2.3. Biểu đồ luồng dữ liệu mức đỉnh
Từ những phân tích trên, ta có thể xây dựng biểu đồ luồng dữ liệu mức đỉnh của hệ thống như sau:
Hình 3.3: Biểu đồ luồng dữ liệu mức đỉnh của hệ thống
Đặc tả chức năng “Hệ thống”
Đầu đề:
Tên chức năng: Hệ thống.
Đầu vào: mật khẩu thay đổi.
Đầu ra: thông tin đổi mật khẩu.
Thân:
Khi nhân viên đăng nhập vào hệ thống có thể tiến hành đổi mật khẩu. Hệ thống sẽ gửi lại các thông tin đổi mật khẩu mà nhân viên cần cung cấp cho hệ thống.
Nhà quản lý khi đăng nhập vào hệ thống thì cũng có thể tiến hành đổi mật khẩu. Hệ thống sẽ gửi lại các thông tin đổi mật khẩu mà nhà quản lý cần cung cấp cho hệ thống.
Đặc tả chức năng “Nhân sự”
Đầu đề:
Tên chức năng: Nhân sự.
Đầu vào: tìm kiếm/ cập nhật nhân sự, thông tin cần xem về nhân viên.
Đầu ra: kết quả tìm kiếm/ cập nhật nhân sự, thông tin nhân viên.
Thân:
Khi nhà quản lý có yêu cầu tìm kiếm hoặc cập nhật nhân sự thì chức năng nhân sự sẽ tìm kiếm trong kho nhân sự hoặc lưu các thông tin cập nhật vào kho nhân viên và chuyển cho nhà quản lý kết quả mà họ yêu cầu.
Nhân viên khi đưa yêu cầu các thông tin cần xem về nhân viên đó thì chức năng nhân sự sẽ lấy dữ liệu từ kho nhân viên gửi cho nhân viên các thông tin nhân viên liên quan tới nhân viên đó.
Đặc tả chức năng “Báo cáo”
Đầu đề:
Tên chức năng: Báo cáo.
Đầu vào: danh sách báo cáo.
Đầu ra: các báo cáo theo yêu cầu.
Thân:
Khi nhà quản lý gửi yêu cầu tới chức năng này muốn xem danh sách các báo cáo liên quan tới nhân viên trong công ty thì chức năng này sẽ gửi lại cho nhà quản lý danh sách nhân viên theo yêu cầu.
3.2.4. Biểu đồ luồng dữ liệu mức dưới đỉnh
3.2.3.1. Biểu đồ dữ liệu mức dưới đỉnh chức năng “Hệ thống”
Hình 3.4: Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “ Hệ thống”
Đặc tả chức năng “Đổi mật khẩu”
Đầu đề:
Tên chức năng: Đổi mật khẩu.
Đầu vào: yêu cầu đổi mật khẩu, đổi mật khẩu cũ.
Đầu ra: thông tin đổi mật khẩu, thông tin thay đổi mật khẩu.
Thân:
Khi người dùng hoặc nhà quản lý có nhu cầu đổi mật khẩu thì sẽ gửi yêu cầu cho hệ thống. Hệ thống với chức năng đổi mật khẩu sẽ gửi lại cho người dùng thông tin đổi mật khẩu. Các thông tin này sau khi hoàn chỉnh sẽ được lưu vào kho người dùng.
Đặc tả chức năng “Quản trị người sử dụng”
Đầu đề:
Tên chức năng: Quản trị người sử dụng.
Đầu vào: đăng nhập, đăng ký người sử dụng mới, người sử dụng mới.
Đầu ra: thông tin đăng ký, thông tin người sử dụng.
Thân:
Nhân viên và nhà quản lý cần đăng nhập vào hệ thống quản trị để có thể thực hiện một số chức năng khác của chương trình. Nếu chưa đăng ký thì có thể đăng ký. Hệ thống sẽ gửi tới nhà quản lý hoặc nhân viên thông tin cần đăng ký. Trong quá trình đăng nhập/ đăng ký đều có sự kiểm tra xem các thông tin cung cấp đã chính xác hoặc đã tồn tại hay chưa. Nếu chưa đúng hoặc chưa chính xác sẽ đưa ra thông báo cho người dùng biết để điều chỉnh.
Đặc tả chức năng “Cập nhật danh mục từ điển”
Đầu đề:
Tên chức năng: Cập nhật danh mục từ điển.
Đầu vào: cập nhật dữ liệu.
Đầu ra: các thông tin cập nhật.
Thân :
Khi nhà quản lý có nhu cầu cập nhật danh mục từ điển thì sẽ gửi yêu cầu cập nhật dữ liệu tới chức năng cập nhật danh mục từ điển. Chức năng này sẽ yêu cầu nhà quản lý cung cấp các thông tin cập nhật. Các thông tin này sau khi được cập nhật sẽ được lưu vào các kho dữ liệu khác nhau.
3.2.3.2. Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “Nhân sự”
Hình 3.5: Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “ Nhân sự”
Đặc tả chức năng “Cập nhật hồ sơ”
Đầu đề:
Tên chức năng: Cập nhật hồ sơ.
Đầu vào: cập nhật hồ sơ nhân viên, xem thông tin nhân viên.
Đầu ra: thông tin nhân viên cần cập nhật, thông tin nhân viên.
Thân:
Nhà quản lý gửi yêu cầu cập nhật hồ sơ nhân viên tới chức năng cập nhật hồ sơ. Chức năng này sẽ yêu cầu nhà quản lý cung cấp các thông tin theo yêu cầu. Sau khi các thông tin được cung cấp đầy đủ thì sẽ được lưu vào kho là thông tin nhân viên.
Nhân viên khi có yêu cầu xem thông tin thì chức năng này sẽ lấy các thông tin từ kho thông tin nhân viên và gửi lại cho nhân viên các thông tin liên quan tới nhân viên đó.
Đặc tả chức năng “ Tìm kiếm nhân sự”
Đầu đề:
Tên chức năng: Tìm kiếm nhân sự.
Đầu vào: yêu cầu tìm kiếm nhân sự.
Đầu ra: kết quả tìm kiếm.
Thân:
Nhà quản lý gửi yêu cầu tìm kiếm nhân sự tới chức năng tìm kiếm nhân sự. Chức năng này sẽ dựa vào các thông tin từ kho thông tin nhân viên đưa ra kết quả tìm kiếm cho các nhà quản lý .
Đặc tả chức năng “ Quản lý theo phòng ban”
Đầu đề:
Tên chức năng: Quản lý theo phòng ban.
Đầu vào: quản lý theo phòng ban.
Đầu ra: danh sách nhân viên theo phòng ban.
Thân:
Nhà quản lý gửi yêu cầu quản lý nhân viên theo phòng ban tới chức năng quản lý theo phòng ban. Chức năng dựa vào kho thông tin nhân viên đưa ra danh sách nhân viên theo phòng ban cho nhà quản lý .
3.2.3.3. Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “Báo cáo”
Hình 3.6: Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “ Báo cáo”
Đặc tả chức năng “ Báo cáo chức vụ”
Đầu đề:
Tên chức năng: Chức vụ.
Đầu vào: hồ sơ nhân viên theo chức vụ.
Đầu ra: DSNV chức vụ.
Thân:
Nhà quản lý gửi yêu cầu xem hồ sơ nhân viên theo chức vụ tới chức năng báo cáo chức vụ. Chức năng này sẽ dựa vào các thông tin lấy từ kho thông tin nhân viên đưa ra danh sách nhân viên theo chức vụ cho nhà quản lý .
Đặc tả chức năng “Báo cáo phòng ban”
Đầu đề:
Tên chức năng: Phòng ban.
Đầu vào: yêu cầu DSNV theo phòng ban.
Đầu ra: danh sách nhân viên phòng ban.
Thân:
Nhà quản lý gửi yêu cầu xem hồ sơ nhân viên theo phòng ban tới chức năng báo cáo phòng ban. Chức năng này sẽ dựa vào các thông tin lấy từ kho thông tin nhân viên đưa ra danh sách nhân viên theo phòng ban cho nhà quản lý .
Đặc tả chức năng “ Báo cáo bằng cấp”
Đầu đề:
Tên chức năng: bằng cấp.
Đầu vào: yêu DSNV theo bằng cấp.
Đầu ra: DSNV bằng cấp.
Thân:
Nhà quản lý gửi yêu cầu xem danh sách nhân viên theo bằng cấp tới chức năng báo cáo bằng cấp. Chức năng này sẽ dựa vào các thông tin lấy từ kho thông tin nhân viên đưa ra danh sách nhân viên theo bằng cấp cho nhà quản lý .
Đặc tả chức năng “Báo cáo khen thưởng - kỷ luật”
Đầu đề:
Tên chức năng: khen thưởng- kỷ luật.
Đầu vào: yêu cầu DSNV KT-KL.
Đầu ra: DSNV khen thưởng.
Thân:
Nhà quản lý gửi yêu cầu xem danh sách nhân viên được khen thưởng/ kỷ luật tới chức năng báo cáo khen thưởng – kỷ luật. Chức năng này sẽ dựa vào các thông tin lấy từ kho thông tin nhân viên đưa ra danh sách nhân viên được khen thưởng / kỷ luật cho nhà quản lý .
Đặc tả chức năng “ Báo cáo hợp đồng”
Đầu đề:
Tên chức năng: Hợp đồng.
Đầu vào: y/c DSNV hợp đồng.
Đầu ra: DSNV hợp đồng.
Thân:
Nhà quản lý gửi yêu cầu xem danh sách nhân viên theo hợp đồng tới chức năng báo cáo hợp đồng. Chức năng này sẽ dựa vào các thông tin lấy từ kho thông tin nhân viên đưa ra danh sách nhân viên theo từng loại hợp đồng cho nhà quản lý .
Đặc tả chức năng “ Báo cáo thay đổi công tác”
Đầu đề:
Tên chức năng: Thay đổi công tác.
Đầu vào: yêu cầu DSNV thay đổi công tác.
Đầu ra: DSNV thay đổi công tác.
Thân:
Nhà quản lý gửi yêu cầu xem danh sách nhân viên thay đổi công tác tới chức năng báo cáo thay đổi công tác. Chức năng này sẽ dựa vào các thông tin lấy từ kho thông tin nhân viên đưa ra danh sách nhân viên thay đổi công tác cho nhà quản lý .
3.2.3.4. Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “Cập nhật danh mục từ điển”
Hình 3.7: Biểu đồ luồng dữ liệu mức dưới đỉnh chức năng “ Cập nhật danh mục từ điển”
Đặc tả chức năng “Cập nhật chức vụ”
Đầu đề:
Tên chức năng: Chức vụ.
Đầu vào: cập nhật chức vụ.
Đầu ra: thông tin chức vụ cần cập nhật.
Thân:
Nhà quản lý muốn cập nhật chức vụ, chức năng chức vụ sẽ gửi các thông tin chức vụ cần cập nhật tới nhà quản lý. Các thông tin khi được cập nhật sẽ được kiểm tra và lưu vào kho chức vụ.
Đặc tả chức năng “Cập nhật phòng ban”
Đầu đề:
Tên chức năng: Phòng ban.
Đầu vào: cập nhật phòng ban.
Đầu ra: thông tin phòng ban cập nhật.
Thân:
Nhà quản lý muốn cập nhật phòng ban, chức năng phòng ban sẽ gửi các thông tin phòng ban cần cập nhật tới nhà quản lý. Các thông tin khi được cập nhật sẽ được kiểm tra và lưu vào kho phòng ban.
Đặc tả chức năng “Cập nhật chuyên ngành”
Đầu đề:
Tên chức năng: Chuyên ngành.
Đầu vào: cập nhật chuyên ngành.
Đầu ra: thông tin chuyên ngành cập nhật.
Thân:
Nhà quản lý muốn cập nhật chuyên ngành, chức năng chuyên ngành sẽ gửi các thông tin chuyên ngành cần cập nhật tới nhà quản lý. Các thông tin khi được cập nhật sẽ được kiểm tra và lưu vào kho chuyên ngành.
Đặc tả chức năng “ Cập nhật loại hợp đồng”
Đầu đề:
Tên chức năng: Loại hợp đồng.
Đầu vào: cập nhật loại hợp đồng.
Đầu ra: thông tin loại hợp đồng cập nhật.
Thân:
Nhà quản lý muốn cập nhật loại hợp đồng, chức năng loại hợp đồng sẽ gửi các thông tin loại hợp đồng cần cập nhật tới nhà quản lý. Các thông tin khi được cập nhật sẽ được kiểm tra và lưu vào kho hợp đồng.
3.3. SƠ ĐỒ THỰC THỂ - LIÊN KẾT (E – R)
3.2.1. Xác định các thực thể
Dựa vào khảo sát thực tế và phân tích trên, ta có thể xác định được các thực thể và các thuộc tính tương ứng của hệ thống như sau:
Nhân viên (mã nhân viên, họ tên nhân viên, ngày sinh, quê quán, hộ khẩu, địa chỉ, quốc tịch, dân tộc, tôn giáo, giới tính, trình độ văn hóa, điện thoại, Email, ngày vào công ty, thâm niên công tác, số chứng minh nhân dân): Lưu trữ các thông tin về nhân viên trong công ty.
Hợp đồng (mã hợp đồng, loại hợp đồng): Lưu trữ các thông tin về hợp đồng.
Chuyên ngành (mã chuyên ngành, tên chuyên ngành): Lưu trữ các thông tin về chuyên ngành đào tạo.
Phòng ban (mã phòng ban, tên phòng ban, số điện thoại ): Lưu trữ các thông tin về các phòng ban trong công ty.
Chức vụ (mã chức vụ, tên chức vụ, mã quyền): Lưu trữ các thông tin về chức vụ.
Khen thưởng/kỷ luật (mã lí do, tên lí do): Lưu trữ các thông tin về lí do khen thưởng hoặc bị kỷ luật.
Nhân viên công tác (mã nhân viên, mã chức vụ, ngày bắt đầu công tác, ngày kết thúc công tác, tên công ty, ghi chú): Lưu trữ các thông tin về quá trình công tác của từng nhân viên.
Thay đổi (mã nhân viên, mã phòng ban, mã chức vụ, ngày chuyển, nơi đến, lí do chuyển): Lưu trữ các thông tin về thay đổi của từng nhân viên.
Quyền truy cập (mã quyền, tên quyền, mã chức năng): Lưu trữ các thông tin về quyền truy cập của từng nhân viên.
Chức năng (mã chức năng, tên chức năng): Lưu trữ các thông tin về từng chức năng của hệ thống.
3.2.2. Xác định các liên kết
Dựa vào việc xác định các thực thể và các thuộc tính như trên ta có thể xác định được liên kết giữa các thực thể đó như sau:
* Liên kết giữa thực thể Hợp đồng và thực thể Nhân viên là liên kết nhiều - nhiều.
Liên kết nhiều – nhiều này sẽ được tách thành hai liên kết 1 - nhiều và có thêm thực thể Hợp đồng nhân viên
* Liên kết giữa thực thể Phòng ban và thực thể Nhân viên là liên kết 1 – nhiều. Mỗi phòng ban có nhiều nhân viên và mỗi nhân viên chỉ có thể thuộc một phòng ban.
* Liên kết giữa thực thể Nhân viên và thực thể Thay đổi là liên kết 1- nhiều.
* Liên kết giữa thực thể Khen thưởng/ kỷ luật và thực thể Nhân viên là liên kết nhiều - nhiều.
Liên kết nhiều – nhiều này sẽ được tách thành hai liên kết 1 - nhiều và có thêm thực thể Nhân viên khen thưởng
* Liên kết giữa thực thể Chuyên ngành và thực thể Nhân viên là liên kết nhiều - nhiều.
Liên kết nhiều – nhiều này sẽ được tách thành hai liên kết 1 - nhiều và có thêm thực thể Bằng cấp nhân viên
* Liên kết giữa thực thể Chức năng và thực thể Quyền truy cập là liên kết 1- nhiều.
* Liên kết giữa thực thể Quyền truy cập và thực thể Chức vụ là liên kết 1- nhiều.
* Liên kết giữa thực thể Chức vụ và thực thể Nhân viên là liên kết 1- nhiều.
* Liên kết giữa thực thể Nhân viên với thực thể Nhân viên công tác là liên kết 1- nhiều:
Như vậy, sau khi tiến hành tách các liên kết nhiều – nhiều thành các liên kết 1 – nhiều, hệ thống bao gồm các thực thế với các thuộc tính tương ứng:
Nhân viên (mã nhân viên, họ tên nhân viên, ngày sinh, quê quán, hộ khẩu, địa chỉ, quốc tịch, dân tộc, tôn giáo, giới tính, trình độ văn hóa, điện thoại, Email, ngày vào công ty, mã phòng ban, mã chức vụ, thâm niên công tác, số chứng minh nhân dân): Lưu trữ các thông tin về nhân viên trong công ty.
Hợp đồng (mã hợp đồng, loại hợp đồng): Lưu trữ các thông tin về hợp đồng.
Chuyên ngành (mã chuyên ngành, tên chuyên ngành): Lưu trữ các thông tin về chuyên ngành đào tạo.
Phòng ban (mã phòng ban, tên phòng ban, số điện thoại ): Lưu trữ các thông tin về các phòng ban trong công ty.
Chức vụ (mã chức vụ, tên chức vụ, mã quyền): Lưu trữ các thông tin về chức vụ.
Khen thưởng/kỷ luật (mã lí do, tên lí do): Lưu trữ các thông tin về lí do khen thưởng hoặc bị kỷ luật.
Hợp đồng nhân viên (mã nhân viên, mã hợp đồng, ngày kí hợp đồng, ngày kết thúc hợp đồng, tình trạng hợp đồng, ghi chú): Lưu trữ các thông tin liên quan tới hợp đồng của từng nhân viên trong công ty.
Nhân viên công tác (mã nhân viên, mã chức vụ, ngày bắt đầu công tác, ngày kết thúc công tác, tên công ty, ghi chú): Lưu trữ các thông tin về quá trình công tác của từng nhân viên.
Nhân viên khen thưởng (mã nhân viên, mã lí do, ngày khen thưởng kỷ luật, ghi chú): Lưu trữ các thông tin về khen thưởng hoặc kỷ luật của từng nhân viên.
Bằng cấp nhân viên (mã nhân viên, mã chuyên ngành, mã bằng cấp, tên trường, hình thức đào tạo, loại bằng): Lưu trữ các thông tin về bằng cấp của từng nhân viên.
Thay đổi (mã nhân viên, mã phòng ban, mã chức vụ, ngày chuyển, nơi đến, lí do chuyển): Lưu trữ các thông tin về thay đổi của từng nhân viên.
Quyền truy cập (mã quyền, tên quyền, mã chức năng): Lưu trữ các thông tin về quyền truy cập của từng nhân viên.
Chức năng (mã chức năng, tên chức năng): Lưu trữ các thông tin về từng chức năng của hệ thống.
3.2.3. Xây dựng sơ đồ thực thể - liên kết (E-R)
Hình 3.8 : Sơ đồ thực thể liên kết (E-R)
CHƯƠNG 4:THIẾT KẾ VÀ CÀI ĐẶT HỆ THỐNG
4.1. THIẾT KẾ CƠ SỞ DỮ LIỆU
4.1.1. Thiết kế các bảng dữ liệu
* Bảng nhanvien
Mục đích: Lưu trữ các thông tin liên quan tới nhân viên trong công ty. Mỗi nhân viên có một mã riêng. Dựa vào bảng này cũng cho biết nhân viên thuộc phòng ban nào, chức vụ gì.
Khoá chính: maNV.
Khoá ngoại: maPB, maCV.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maNV
Varchar
5
Not null
Mã nhân viên
Khoá chính
2
hotenNV
Varchar
50
Họ tên nhân viên
3
Ngaysinh
Date
Ngày sinh của nhân viên
4
Quequan
Varchar
50
Quê quán
5
Hokhau
Varchar
50
Hộ khẩu
6
Diachi
Varchar
50
Địa chỉ
7
Quoctich
Varchar
50
Quốc tịch
8
Dantoc
Varchar
20
Dân tộc
9
Tongiao
Int
1
Tôn giáo
10
TDVH
Varchar
10
Trình độ văn hoá
11
Dienthoai
Int
11
điện thoại
12
Email
Varchar
40
Điạ chỉ email
13
Ngayvaoct
Date
Ngày vào công ty
14
maPB
Varchar
5
Not null
Mã phòng ban
Khóa ngoại Lookup từ bảng phongban
15
maCV
Varchar
5
Not null
Mã chức vụ
Khóa ngoại Lookup từ bảng chucvu
16
Thamnienct
Int
3
Thâm niên công tác (năm)
17
soCMND
Int
11
Số chứng minh nhân dân
18
Gioitinh
Int
1
Giới tính
*Bảng phongban
Mục đích: Lưu trữ thông tin về các phòng ban trong công ty. Mỗi phòng ban có một mã để phân biệt. Mỗi mã ứng với tên phòng ban khác nhau, số điện thoại khác nhau.
Khóa chính: maPB.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maPB
Varchar
5
Not null
Mã phòng ban
Khoá chính
2
tenPB
Varchar
100
Tên phòng ban
3
soDT
Int
11
Số điện thoại
*Bảng chucvu
Mục đích: Lưu trữ các loại chức vụ trong công ty. Mỗi chức vụ có một mã riêng, một tên chức vụ riêng. Mỗi mã chức vụ lại có một mã quyền riêng. Mã quyền này sẽ cho biết chức vụ đó được phép sử dụng những chức năng nào trong hệ thống.
Khóa chính: maCV.
Khóa ngoại: maquyen.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maCV
Varchar
5
Not null
Mã chức vụ
Khoá chính
2
tenCV
Varchar
50
Tên chức vụ
3
Maquyen
Varchar
5
Not null
Mã quyền
Khóa ngoại Lookup từ bảng quyentruycap
* Bảng hdld
Mục đích: Bảng lưu trữ thông tin về tên các loại hợp đồng. Mỗi loại hợp đồng có một mã riêng để phân biệt.
Khóa chính: maHD.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maHD
Varchar
5
Not null
Mã hợp đồng
Khoá chính
2
tenHD
Varchar
100
Tên hợp đồng
* Bảng chuyennganh
Mục đích: Lưu trữ các chuyên ngành mà nhân viên được đào tạo. Mỗi chuyên ngành được phân biệt với nhau bởi một mã chuyên ngành.
Khóa chính: maCN.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maCN
Varchar
5
Not null
Mã chuyên ngành
Khoá chính
2
tenCN
Varchar
100
Tên chuyên ngành
* Bảng kt_kl
Mục đích: Lưu trữ các loại hình thức khen thưởng hoặc kỷ luật. Mỗi loại được phân biệt với nhau bởi một mã lí do riêng.
Khóa chính: maLD.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maLD
Varchar
5
Not null
Mã lí do
Khoá chính
2
tenLD
Varchar
100
Tên lí do
* Bảng nv_hdld
Mục đích: Lưu trữ thông tin về hợp đồng lao động của nhân viên với công ty.
Khóa ngoại: maNV, maHD.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maNV
Varchar
5
Not null
Mã nhân viên
Khóa ngoại Lookup từ bảng nhanvien
2
maHD
Varchar
5
Not null
Mã hợp đồng
Khóa ngoại Lookup từ bảng hopdong
3
ngaykiHD
Date
Ngày kí hợp đồng
4
ngayketthucHD
Date
Ngày kết thúc hợp đồng
5
tinhtrangHD
Varchar
50
Tình trạng hợp đồng
* Bảng nv_ct
Mục đích: Lưu trữ thông tin về quá trình công tác của một nhân viên trước khi vào công ty.
Khóa ngoại: maNV, maCV.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maNV
Varchar
5
Not null
Mã nhân viên
Khóa ngoại Lookup từ bảng nhanvien
2
maCV
Varchar
5
Not null
Mã chức vụ
Khóa ngoại Lookup từ bảng chucvu
3
ngayBDCT
Date
Ngày bắt đầu công tác
4
ngayKTCT
Date
Ngày kết thúc công tác
5
Ghichu
Varchar
300
Ghi chú
* Bảng nv_bangcap
Mục đích: Lưu trữ thông tin về bằng cấp của một nhân viên trong công ty.
Khóa chính: maBC.
Khóa ngoại: maNV, maCN.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maNV
Varchar
5
Not null
Mã nhân viên
Khóa ngoại Lookup từ bảng nhanvien
2
maCN
Varchar
5
Not null
Mã chuyên ngành
Khóa ngoại Lookup từ bảng chuyennganh
3
maBC
Varchar
5
Not null
Mã bằng cấp
Khóa chính
4
Tentruong
Varchar
50
Tên trường đào tạo
5
hinhthucDT
Varchar
50
Hình thức đào tạo
6
Loaibang
Varchar
20
Loại bằng được cấp
* Bảng nv_ktkl
Mục đích: Lưu trữ thông tin những nhân viên nào được khen thưởng hoặc bị kỷ luật.
Khóa ngoại: maNV, maLD.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maNV
Varchar
5
Not null
Mã nhân viên
Khóa ngoại Lookup từ bảng nhanvien
2
maLD
Varchar
5
Not null
Mã lí do
Khóa ngoại Lookup từ bảng KT-KL
3
ngayKTKL
Date
Ngày khen thưởng/ kỷ luật
4
Ghichu
Varchar
300
Ghi chú
*Bảng thaydoi
Mục đích: Lưu trữ thông tin của những nhân viên rời khỏi công ty với những lí do chuyển đivà công ty sẽ chuyển tới.
Khóa ngoại: maNV, maPB, maCV.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maNV
Varchar
5
Not null
Mã nhân viên
Khóa ngoại Lookup từ bảng nhanvien
2
maPB
Varchar
5
Not null
Mã phòng ban
Khóa ngoại Lookup từ bảng phongban
3
maCV
Varchar
5
Not null
Mã chức vụ
Khóa ngoại Lookup từ bảng chucvu
4
Ngaychuyen
Date
Ngày chuyển đi
5
Noiden
Varchar
200
Nơi nhân viên chuyển đến
6
Lidochuyen
Varchar
50
Lí do chuyển đi
* Bảng quyentruycap
Mục đích: Lưu trữ các quyền được sử dụng của người dùng đối với từng chức năng.
Khóa chính: maquyen.
Khóa ngoại: machucnang.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
maquyen
Varchar
5
Not null
Mã quyền
Khóa chính
2
tenquyen
Varchar
50
Tên quyền
3
machucnang
Varchar
5
Not null
Mã chức năng
Khóa ngoại Lookup từ bảng chucnang
* Bảng chucnang
Mục đích: Lưu trữ các chức năng của hệ thống. Ứng với mỗi chức năng sẽ có một mã riêng để phân biệt.
Khóa chính: machucnang.
Cấu trúc bảng:
STT
Tên trường
Kiểu DL
Độ dài
Ràng buộc
Diễn giải
Ghi chú
1
machucnang
Varchar
5
Not null
Mã chức năng
Khóa chính
2
tenchucnang
Varchar
200
Tên chức năng
4.1.2. Mối quan hệ giữa các bảng dữ liệu
Hình 4.1: Mối quan hệ giữa các bảng dữ liệu
4.2. THIẾT KẾ GIAO DIỆN MÀN HÌNH
Từ những phân tích, thiết kế hệ thống đã trình bày ở trên, đòi hỏi thiết kế giao diện thỏa mãn được các yêu cầu đặt ra và thiết kế môi trường giao tiếp giữa người sử dụng và máy tính thỏa mãn điều kiện: dễ sử dụng, dễ học, dễ nhớ, tốc độ thao tác nhanh, kiểm soát tốt, dễ phát triển. Hệ thống được thiết kế với giao diện dễ sử dụng, người dùng có thể dễ dàng thích ứng được với các chức năng chính của chương trình.
Để có thể truy nhập vào chương trình thì người dùng cần có tài khoản. Nếu chưa có thì có thể đăng ký một tài khoản.
Sau đây là một số giao diện và mẫu báo cáo khi thực hiện chương trình.
4.2.1 Một số giao diện khi thực hiện chương trình
4.2.1.1. Màn hình giao diện đăng nhập vào chương trình
Hình 4.2: Giao diện màn hình đăng nhập vào chương trình
* Hoạt động của giao diện màn hình “ Đăng nhập” vào chương trình
Người dùng nhập tên truy nhập và password vào. Khi nhấn nút Đăng nhập thì các thông tin mà người dùng cung cấp sẽ được kiểm tra. Nếu thông tin không đầy đủ, thông tin sai hoặc là chưa có người dùng này thì hệ thống sẽ đưa ra thông báo và yêu cầu người dùng truy nhập lại. Nếu thông tin cung cấp đúng thì hệ thống sẽ chuyển tới trang đăng nhập thành công.
Nếu người dùng chưa có tài khoản có thể đăng ký tạo mới một tài khoản bằng cách tích vào chữ Đăng ký
4.2.1.2. Màn hình giao diện của chương trình
Khi đăng nhập thành công thì hệ thống sẽ chuyển tới chương trình chính có giao diện như sau:
Hinh 4.3: Giao diện màn hình của chương trình
4.2.1.3. Giao diện màn hình “Đổi mật khẩu”
Hinh 4.4: Giao diện màn hình “Đổi mật khẩu”
* Hoạt động của giao diện màn hình “ Đổi mật khẩu”
Muốn đổi mật khẩu, người dùng cần nhập lại mật khẩu cũ, mật khẩu mới, và xác nhận mật khẩu. Khi kích vào nút Chấp nhận thì hệ thống sẽ tiến hành kiểm tra các thông tin mà người dùng vừa nhập vào. Nếu chưa có thông tin nào, mật khẩu cũ sai hoặc mật khẩu mới và việc xác nhận lại mật khẩu không giống nhau thì hệ thống sẽ đưa ra thông báo và yêu cầu người dùng nhập lại các thông tin đó. Nếu các thông tin đầy đủ và chính xác thì hệ thống sẽ thực hiện thao tác đổi mật khẩu và đưa ra thông báo đổi thành công mật khẩu. Nếu không muốn đổi mật khẩu nữa thì người dùng có thể nhấn vào nút Hủy bỏ.
4.2.1.4. Giao diện màn hình “Cập nhật chức vụ”
Hình 4.5: Giao diện màn hình “ Cập nhật chức vụ”
* Hoạt động của giao diện màn hình “ Cập nhật chức vụ ”
Khi nhấn vào nút Sửa thì hệ thống sẽ đưa ra một form sửa tương ứng với mã chức vụ đó.
Hình 4.6: Giao diện màn hình “Sửa chức vụ”
Tại màn hình giao diện này bạn chỉ được phép sửa các thông tin khác mà không được phép sửa mã chức vụ. Sau khi sửa xong, nhấn vào nút Cập nhật thì hệ thống sẽ đưa lại danh sách chức vụ mà trong đó chức vụ bạn chọn đã được sửa. Nếu không muốn sửa thì có thể nhấn vào nút Hủy bỏ.
Khi nhấn vào nút Xóa thì hệ thống sẽ xóa bỏ chức vụ đó ra khỏi danh sách chức vụ.
Khi nhấn vào thêm mới:
Hình 4.7: Giao diện màn hình “Thêm mới chức vụ”
4.2.1.5. Giao diện màn hình “Quản lý theo phòng ban”
Hình 4.8: Giao diện màn hình “Quản lý theo phòng ban”
* Hoạt động của giao diện màn hình “Quản lý theo phòng ban”
Muốn xem thông tin về phòng ban nào thì chỉ cần nhấn vào tên phòng ban đó.
Hình 4.9: Giao diện màn hình danh sách theo phòng ban “Phòng nhân sự”
4.2.2. Một số mẫu báo cáo khi thực hiện chương trình
4.2.2.1. Báo cáo danh sách nhân viên theo chức vụ
Hình 4.10: Báo cáo danh sách nhân viên theo “Chức vụ”
4.2.2.2. Báo cáo nhân viên theo phòng ban
Hình 4.11: Báo cáo danh sách nhân viên theo “Phòng ban”
4.2.2.3. Báo cáo danh sách nhân viên theo hợp đồng
Hình 4.12: Báo cáo danh sách nhân viên theo “ Loại hợp đồng”
4.2.2.4. Báo cáo danh sách nhân viên thay đổi công tác
Hình 4.13: Báo cáo danh sách nhân viên “Thay đổi công tác”
4.2.2.5. Báo cáo danh sách nhân viên theo bằng cấp
Hình 4.14: Báo cáo danh sách nhân viên theo “Bằng cấp”
4.2.2.6. Báo cáo danh sách nhân viên khen thưởng/ kỷ luật
Hình 4.15: Báo cáo danh sách nhân viên “Khen thưởng/ kỷ luật”
4.3. THIẾT KẾ KIỂM SOÁT
Mục đích của việc thiết kế kiểm soát là để hệ thống hoạt động đúng đắn, hiệu quả, tăng độ tin cậy của thông tin hệ thống, phòng tránh hay hạn chế tối đa các nguy cơ gây mất mát, hư hỏng thông tin gây đe dọa sự hoạt động của hệ thống do ngẫu nhiên hay cố ý.
Mục đích của hệ thống cũng là đề xuất các biện pháp nhằm làm cho hệ thống đảm bảo được.
Các khía cạnh cần quan tâm của thiết kế kiểm soát là: tính chính xác, tính an toàn, tính bảo mật, tính riêng tư.
4.3.1. Xác định nhu cầu bảo mật của hệ thống
Hệ thống cho phép phân quyền sử dụng, từ đó chống được những truy nhập bất hợp pháp vào hệ thống dữ liệu, đồng thời định rõ được trách nhiệm trong trường hợp có sự cố.
4.3.2. Chế độ sao lưu, phục hồi dữ liệu
Để đảm bảo tính an toàn của hệ thống trong bất cứ trường hợp bất trắc nào có thể xảy ra cho hệ thống, thì công việc sao lưu và phục hồi trong trường hợp cần thiết là công việc được thực hiện một cách có chu kỳ đối với hệ thống này của công ty. Công việc sao lưu phải thực hiện theo chu kỳ mỗi tuần một lần để tránh gặp các trường hợp xấu xảy ra.
Các bảng dữ liệu cần phải sao lưu đó là: nhân viên, nv_hdld (nhân viên – hợp đồng lao động), nv-ct (nhân viên – công tác), nv-ktkl (nhân viên – khen thưởng kỷ luật), nv_bangcap (nhân viên – bằng cấp), thay đổi, quyền truy cập, chức vụ.
Bảng dữ liệu
Mức thấp
Mức trung bình
Mức cao
Nhân viên
Nv_hdld
Nv_ct
Nv_ktkl
Nv_bằng cấp
Thay đổi
Quyền truy cập
Chức vụ
Bảng 4.1: Sao lưu dữ liệu
4.3.3. Phân định các nhóm người dùng
Trong hệ thống này có 5 nhóm người sử dụng đó là:
Giám đốc.
Phó giám đốc.
Trưởng phòng.
Phó phòng.
Nhân viên.
4.3.4. Quy định quyền hạn cho các nhóm người dùng
Xây dựng quyền hạn cho mỗi nhóm theo từng chức năng của hệ thống.
Được sử dụng = Yes (Y).
Không được sử dụng = No (N).
Giám đốc
Phó giám đốc
Trưởng phòng
Phó phòng
Nhân viên
1. Hệ thống
Đổi mật khẩu
Y
Y
Y
Y
Y
Quản trị người dùng
Y
N
N
N
Y
Cập nhật danh mục từ điển
Chức vụ
Y
Y
N
N
N
Phòng ban
Y
Y
Y
Y
N
Chuyên ngành
Y
Y
Y
N
N
Loại hợp đồng
Y
Y
N
N
N
2. Nhân sự
Cập nhật hồ sơ nhân sự
Y
Y
Y
N
Y
Tìm kiếm nhân sự
Y
Y
Y
Y
N
Quản lý theo phòng ban
Y
Y
Y
N
N
3. Báo cáo
Chức vụ
Y
Y
N
N
N
Phòng ban
Y
Y
Y
Y
N
Loại hợp đồng
Y
Y
N
N
N
Bằng cấp
Y
Y
Y
N
N
Khen thưởng - Kỷ luật
Y
Y
Y
N
N
Thay đổi công tác
Y
Y
Y
N
N
Bảng 4.2: Phân định quyền hạn người dùng
4.4. HƯỚNG DẪN CÀI ĐẶT VÀ SỬ DỤNG CHƯƠNG TRÌNH
4.4.1. Hướng dẫn cài đặt chương trình
4.4.1.1. Yêu cầu về phần cứng
Ram 256 MB là yêu cầu tối thiểu nếu chạy trên Windows XP, còn nếu chạy trên Windows Server 2003 thì yêu cầu tối thiểu ram 512 MB, tốc độ chip tối thiểu 2.4 GHz, pentium IV.
4.4.1.2. Yêu cầu về phần mềm
Windows XP hoặc Windows Server 2003 có cài Apache, MySQL, PHP.
Cài đặt Crystal report_ công cụ tạo báo cáo
Cài đặt Macromedia Dreamweaver 8 _ công cụ soạn thảo và thiết kế.
4.4.1.3. Cài đặt chương trình
Sau khi cài đặt XAMP SERVER (Bộ cài bao gồm Apache, MySQL, PHP), tiến hành cóp toàn bộ các file và thư mục trong thư mục QLNS vào thư mục C:\wamp\www.
Khởi động Wamp server.
Chọn phpMyadmin
Tạo một CSDL có tên là “quanlynhansu”.
Import file quanlynhansu.sql từ thư mục cơ sở dữ liệu.
Vào trình duyệt IE gõ: Nếu màn hình hiện lên form đăng nhập vào chương trình thì đã cài đặt thành công.
4.4.2. Hướng dẫn sử dụng chương trình
Để đăng nhập vào chương trình bạn có thể tạo mới một username hoặc sử dụng user trang với mật khẩu là: 123.
Với từng form bạn có thể thực hiện các thao tác đã có trên form đó: thêm, sửa, xóa, tìm kiếm.
Muốn xem một báo cáo thì bạn có thể xem trực tiếp hoặc tải về máy.
Hàng tuần bạn cần tiến hành sao lưu các bảng cũng như các dữ liệu liên quan như đã nói ở phần thiết kế kiểm soát.
KẾT LUẬN
I. ĐÁNH GIÁ KẾT QUẢ THU ĐƯỢC
Tích lũy được kinh nghiệm trong việc phân tích và thiết kế hệ thống.
Biết được quy trình quản lý nhân sự trong công ty.
Quản lý tốt việc đăng nhập/đăng ký thành viên.
Cho phép nhân viên hoặc nhà quản lý có thể truy nhập vào và thực hiện đổi mật khẩu..
Cho phép người dùng truy nhập với mã nhân viên và mã chức vụ, mã quyền được quy định trước..
Thêm mới, sửa thông tin, xóa thành công các loại danh mục từ điển: chức vụ, phòng ban, chuyên ngành đào tạo, loại hợp đồng.
Cập nhật hồ sơ nhân sự tốt.
Việc tìm kiếm được thực hiện theo nhiều tiêu chí cho kết quả tốt.
Việc quản lý theo phòng ban tốt. Mỗi phòng ban cho phép xem đầy đủ thông tin về các nhân viên trong phòng ban đó
Thực hiện được các báo cáo tùy theo nhu cầu của nhà quản lý .
Web site hỗ trợ tốt tiếng Việt Unicode.
II. NHỮNG TỒN TẠI CỦA HỆ THỐNG
Giao diện chương trình chưa thân thiện lắm với người dùng.
Chương trình chưa kiểm tra được hết tất cả các trường hợp có thể xảy ra.
Chưa thực hiện được phân quyền cho từng đối tượng sử dụng ứng với từng chức năng của hệ thống.
Việc cập nhật hồ sơ nhân sự còn phải cập nhật đơn lẻ, chưa có sự cập nhật tự động liên kết nhiều bảng với nhau nên dễ gặp phải sai sót.
Việc tạo báo cáo chưa thực hiện tự động được. Muốn xem báo cáo khi mà các thông tin đã được bổ sung thì nhà quản lý cần có một số thao tác trước khi xem được (chạy lại một số file và upload lại).
Chương trình chưa tạo thành module nên việc nâng cấp phần mềm sẽ khó khăn.
III. HƯỚNG PHÁT TRIỂN TRONG TƯƠNG LAI
Xây dựng giao diện thân thiện hơn với người dùng.
Kiểm tra các trường hợp còn thiếu sót.
Thực hiện phân quyền với từng đối tượng sử dụng đã nêu trong phần thiết kế tổng thể
Tận dụng thế mạnh của ngôn ngữ lập trình PHP và các tính năng của ngôn ngữ MySQL để tạo được việc cập nhật hồ sơ nhân viên nhanh nhạy, chính xác hơn.
Tìm hiểu thêm về cách tạo báo cáo để các báo cáo được tự động thay đổi sau mỗi lần sửa đổi, thêm mới thông tin.
TÀI LIỆU THAM KHẢO
[1] Công ty INTECH. Tài liệu hướng dẫn nghiệp vụ quản lý nhân sự tại Công ty INTECH, 2007.
[2] Đặng Minh Ất. Bài giảng phân tích và thiết kế hệ thống (Lưu hành nội bộ). Trường Đại học Kinh tế Quốc dân (Bộ môn CNTT), 2006.
[3] Nguyễn Thúc Hải. Mạng máy tính và các hệ thống mở. NXB Giáo Dục, 1999.
[4] Nguyễn Trung Tuấn, Lưu Minh Tuấn, Tống Minh Ngọc. Cơ sở dữ liệu (Lưu hành nội bộ). Trường Đại học Kinh tế Quốc dân (Bộ môn CNTT), 2006.
[5] Nguyễn Văn Ba. Phân tích và thiết kế hệ thống thông tin. NXB Đại Học Quốc Gia Hà Nội, 2006.
[6] Phạm Hữu Khang. Xây dựng ứng dụng Web bằng PHP & MySQL. NXB Mũi Cà Mau, 2004.
[7] Trung tâm tin học - Đại học khoa học tự nhiên TP.HCM. Tài liệu giảng dạy SQL Server, 2004.
[8] John.Wiley.and. Sons. Visio 2003, Bible.Apr.2004.ebook.
[9] Wrox Press. Profesional PHP Programming, 1999.
[10] Một số Website:
Php_manual.chm
PHỤ LỤC
MỘT SỐ MODULE CHÍNH CỦA CHƯƠNG TRÌNH
* Module đổi mật khẩu
<?php
session_start();
include('config.php');
$act=$_GET['act'];
if($act=='view')
{
include('doimk.htm');
}
if ( $act == 'do' )
{
$ten=$_SESSION['ten'];
$pass1=md5(addslashes($_POST['txtmk']));
$pass2=md5(addslashes($_POST['txtmkm']));
$pass3=md5(addslashes($_POST['txtxnmk']));
//echo $pass1;
$sql= "select*from members where username='$ten'";
$result= mysql_query($sql,$conn);
$member= mysql_fetch_array($result);
if (! $pass1||! $pass2||! $pass3)
{ print "Bạn hãy điền đầy đủ thông tin .Nhấp vào đây để quay trở lại";
exit();
}
elseif($pass1!=$member["password"])
{
print " Mật khẩu của bạn chưa đúng. Nhấp vào đây để quay trở lại";
exit();
}
elseif($pass2!=$pass3)
{
print "Mật khẩu mới và xác nhận mật khẩu không giống nhau. Nhấp vào đây để quay trở lại";
exit();
}
else
{
$sql=mysql_query("update members set password='$pass2' where username='$ten' ");
print " Chúc mừng bạn!.Mật khẩu đã được thay đổi. ";
exit();
}
}
?>
* Module thêm mới chức vụ
<?php
include('config.php');
$act=$_GET['act'];
$id=$_GET['id'];
if($act=='view')
{
$sql=mysql_query("select macv,tencv,maquyen from chucvu");
include('dscv.htm');
}
elseif($act=='sua')
{
$sql=mysql_query("select macv,tencv,maquyen from chucvu where macv='$id'");
$row=mysql_fetch_row($sql);
include('suachucvu.htm');
}
elseif($act=='update')
{ $macv=$_POST['txtmcv'];
$tencv=$_POST['txttencv'];
$quyen=$_POST['quyen'];
$sql=mysql_query("update chucvu set tencv='$tencv',maquyen='$quyen' where macv='$macv' ");
if($sql)
{ $sql=mysql_query("select macv,tencv,maquyen from chucvu");
include('dscv.htm');
}
}
elseif($act=='delete')
{$sql=mysql_query("delete from chucvu where macv='".$id."' ");
if($sql)
{
$sql=mysql_query("select macv,tencv,maquyen from chucvu");
include('dscv.htm');
}
}
elseif($act=='add')
{
include('themmoicv.htm');
}
elseif($act=='in')
{ $macv=$_POST['txtmcv'];
$tencv=$_POST['txttencv'];
$quyen=$_POST['quyen'];
$sql= "select*from chucvu where macv='$macv'";
$result= mysql_query($sql,$conn);
$member= mysql_fetch_array($result);
if ($macv==$member['macv'])
{
print "Mã chức vụ trùng nhau.Nhấp vào đây để quay trở lại";
exit();
} else
{
$sql=mysql_query("insert into chucvu(macv,tencv,maquyen) values('$macv','$tencv','$quyen')");
if($sql)
{ $sql=mysql_query("select macv,tencv,maquyen from chucvu");
include('dscv.htm');
}
}
}
?>
* Module tìm kiếm nhân sự
<?php
include('config.php');
$act=$_GET['act'];
$id=$_GET['id'];
if($act=='view')
{
include('timkiem.htm');
}
elseif($act=='timkiem')
{
$hoten=$_POST['txttnv'];
$manv=$_POST['txtmnv'];
$phongban=$_POST['phongban'];
$chucvu=$_POST['chucvu'];
$thamnienct=$_POST['txttnct'];
$hopdong=$_POST['hopdong'];
$chuyennganh=$_POST['chuyennganh'];
if (!$hoten&& !$manv&& !$phongban&& !$chucvu&& !$thamnienct && !$hopdong && !$chuyennganh)
{echo " alert('Bạn phải điền ít nhất một thông tin!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
elseif ( $hoten )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where hotennv like '%$hoten%'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ( $manv )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where manv='$manv'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";}
else
{
include ("ketquatk.htm");
}
}
elseif ( $phongban )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where mapb='$phongban'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ( $chucvu )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where macv ='$chucvu' ";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ( $thamnienct )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where thamnienct='$thamnienct'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ($hopdong )
{
$sql="select nv_hdld.manv,nhanvien.hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),nhanvien.diachi,nhanvien.dienthoai,nhanvien.mapb,nhanvien.macv from nhanvien,nv_hdld,hopdong where nv_hdld.mahd='$hopdong' and nhanvien.manv=nv_hdld.manv and nv_hdld.mahd=hopdong.mahd";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";}
else
{
include ("ketquatk.htm");
}
}
elseif ( $manv && $chuyennganh )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien,nv_bangcap where nhanvien.manv=nv_bangcap.manv and nv_bangcap.macn='$chuyennganh' and nhanvien.manv='$manv' group by nhanvien.manv";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif($hoten && $manv)
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where manv = '".$manv."' and hotennv ='".$hoten."'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ($hoten && $phongban)
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where hotennv like '%$hoten%' and mapb='$phongban'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ($hoten && $chucvu)
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where hotennv ='$hoten' and macv='$chucvu' ";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ( $manv && $chucvu )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where manv='".$manv."' and macv='".$chucvu."'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";}
else
{
include ("ketquatk.htm");
}
}
elseif ( $phongban && $chucvu )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where mapb='".$phongban."' and macv='".$chucvu."'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ( $manv && $thamnienct )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where manv='$manv' and thamnienct='$thamnienct'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";}
else
{
include ("ketquatk.htm");
}
}
elseif ( $chuyennganh )
{
$sql="select nv_bangcap.manv,nhanvien.hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),nhanvien.diachi,nhanvien.dienthoai,nhanvien.mapb,nhanvien.macv from nhanvien,nv_bangcap,chuyennganh where nv_bangcap.macn='$chuyennganh' and nhanvien.manv=nv_bangcap.manv and nv_bangcap.macn=chuyennganh.macn";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";
}
else
{
include ("ketquatk.htm");
}
}
elseif ( $manv )
{
$sql="select manv,hotennv,DATE_FORMAT(ngaysinh,'%d/%m/%Y'),diachi,dienthoai,mapb,macv from nhanvien where manv='".$manv."'";
$result=mysql_query($sql,$conn);
$num=mysql_num_rows($result);
if ($num==0)
{
echo " alert('Không tìm thấy kết quả như bạn yêu cầu. Hãy thử lại!');";
echo " location.href=\"QLNS.php?page=timkiem&&act=view\"";}
else
{
include ("ketquatk.htm");
}
}
}?>
MỤC LỤC
Trang
DANH MỤC CÁC CHỮ VIẾT TẮT Error! Bookmark not defined.
DANH MỤC CÁC HÌNH Error! Bookmark not defined.
DANH MỤC CÁC BẢNG BIỂU Error! Bookmark not defined.i
DANH MỤC CÁC CHỮ VIẾT TẮT
STT
Từ viết tắt
Ý nghĩa
1
AT&T
American Telephone and Telegraph
2
IBM
International Business Machines Coporation
3
WAN
Wide Area Network
4
LAN
Local Area Network
5
MCI
Media Control Interface
6
HDI
Human Developement Index
7
ARPANET
Advanced Research Projects Agency Network
8
TCP/IP
Transmission Control Protocol/ Internet Protocol
9
DoD
Denial of Service
10
ISP
Internet Service Provider
11
FTP
File Transfer Protocol
12
IRC
Internet Relay Chat
13
WWW
World Wide Web
14
CCNA
Cisco Certified Network Administrator
15
MCSA
Microsoft Certified Systems Administrator
16
KT- KL
Khen thưởng- kỷ kuật
17
DSNV
Danh sách nhân viên
18
PHP
Persional Home Page
19
CSDL
Cơ sở dữ liệu
20
HTML
HyperText Markup Language
Các file đính kèm theo tài liệu này:
- 10292.doc