Tài liệu Đề tài Nghiên cứu, phân tích và thiết kế hệ thống thông tin quản lý nhân sự và lương trong hệ thống hoạch định nguồn lực doanh nghiệp: Luận văn thạc sĩ - 1 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
MỤC LỤC
DANH MỤC CÁC TỪ TIẾNG ANH VÀ VIẾT TẮT ............................................... 4
DANH MỤC CÁC BẢNG ........................................................................................ 4
DANH MỤC CÁC HÌNH, SƠ ĐỒ ........................................................................ 6
MỞ ĐẦU .......................................................................................................................... 7
Mục tiêu, phạm vi của đề tài .......................................................................................... 7
CHƯƠNG I: HỆ THỐNG HOẠCH ĐỊNH NGUỒN LỰC DOANH NGHIỆP - ERP
VÀ CÁC VẤN ĐỀ ĐẶT RA.......................................................................................... 10
I. Khái niệm về ERP. .............................................................................................. 10
II. Hiện trạng ERP ở Việt Nam và n...
121 trang |
Chia sẻ: hunglv | Lượt xem: 1420 | Lượt tải: 0
Bạn đang xem trước 20 trang mẫu tài liệu Đề tài Nghiên cứu, phân tích và thiết kế hệ thống thông tin quản lý nhân sự và lương trong hệ thống hoạch định nguồn lực doanh nghiệp, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
Luận văn thạc sĩ - 1 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
MỤC LỤC
DANH MỤC CÁC TỪ TIẾNG ANH VÀ VIẾT TẮT ............................................... 4
DANH MỤC CÁC BẢNG ........................................................................................ 4
DANH MỤC CÁC HÌNH, SƠ ĐỒ ........................................................................ 6
MỞ ĐẦU .......................................................................................................................... 7
Mục tiêu, phạm vi của đề tài .......................................................................................... 7
CHƯƠNG I: HỆ THỐNG HOẠCH ĐỊNH NGUỒN LỰC DOANH NGHIỆP - ERP
VÀ CÁC VẤN ĐỀ ĐẶT RA.......................................................................................... 10
I. Khái niệm về ERP. .............................................................................................. 10
II. Hiện trạng ERP ở Việt Nam và những bất cập...................................................... 12
III. Lựa chọn phương pháp tiếp cận phát triển hệ thống ERP ..................................... 13
1. Cách tiếp cận hướng chức năng........................................................................... 13
2. Cách tiếp cận hướng đối tượng ............................................................................ 18
3. So sánh sự giống và khác nhau của hai cách tiếp cận trong quá trình phát triển
phần mềm: ............................................................................................................... 20
4. Ưu điểm chính của phương pháp hướng đối tượng ............................................... 21
5. Lựa chọn phương pháp tiếp cận để phát triển Hệ thống thông tin quản trị nhân
sự&Lương trong bài toán ERP. ................................................................................ 22
CHƯƠNG II: QUY TRÌNH PHÂN TÍCH, THIẾT KẾ HƯỚNG ĐỐI TƯỢNG ...... 23
I. Xây dụng mô hình nghiệp vụ ............................................................................... 23
1. Mở đầu ........................................................................................................ 23
2. Tìm hiểu nắm vững nghiệp vụ ...................................................................... 23
II. Xác định yêu cầu ................................................................................................. 25
1. Mở đầu ........................................................................................................ 25
2. Luồng công việc xác định yêu cầu ................................................................ 25
3. Tìm các tác nhân và các ca sử dụng .............................................................. 26
4. Thứ tự ưu tiên các ca sử dụng ....................................................................... 28
5. Mô tả chi tiết một ca sử dụng ....................................................................... 29
6. Tạo bản mẫu Giao diện người dùng .............................................................. 30
7. Cấu trúc mô hình ca sử dụng ........................................................................ 31
III. Phân tích .............................................................................................................. 32
1. Mở đầu ........................................................................................................ 32
2. Luồng công việc phân tích ........................................................................... 33
3. Phân tích kiến trúc........................................................................................ 33
4. Phân tích một ca sử dụng.............................................................................. 36
Luận văn thạc sĩ - 2 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
5. Phân tích một lớp ......................................................................................... 39
6. Phân tích một gói ......................................................................................... 40
IV. Thiết kế ............................................................................................................... 41
1. Mở đầu ........................................................................................................ 41
2. Luồng công việc thiết kế .............................................................................. 42
3. Thiết kế kiến trúc ......................................................................................... 42
4. Thiết kế một ca sử dụng ............................................................................... 46
5. Thiết kế một lớp ........................................................................................... 49
6. Thiết kế một hệ thống con ............................................................................ 52
CHƯƠNG III: HỆ THỐNG QUẢN LÝ NHÂN SỰ - TIỀN LƯƠNG ........................ 54
I. Chức năng nhiệm vụ ............................................................................................ 54
II. Mô tả hoạt động nghiệp vụ quy trình quản lý nhân sự, tiền lương ......................... 55
1.Đặc tả yêu cầu ...................................................................................................... 55
2.Quy trình quản lý nhân sự tiền lương .................................................................... 57
2.1 Biểu đồ hoạt động nghiệp vụ quản lý thông tin tuyển dụng nhân viên ....... 57
2.2 Biểu đồ hoạt động nghiệp vụ quản lý Hợp đồng lao động ......................... 59
2.3 Biểu đồ hoạt động nghiệp vụ quản lý Quá trình công tác .......................... 62
2.4 Biểu đồ hoạt động nghiệp vụ quản lý quá trình khen thưởng, kỷ luật ........ 63
2.5 Biểu đồ hoạt động nghiệp vụ quản lý Quá trình đào tạo ............................ 66
2.6 Biểu đồ hoạt động nghiệp vụ quản lý Lương ............................................ 68
Tổng hợp các chức năng của quy trình quản lý Nhân sự - Tiền lương ......................... 69
III. Phát triển mô hình ca sử dụng .............................................................................. 71
1. Xác định tác nhân ................................................................................................ 71
2. Xác định ca sử dụng............................................................................................. 71
3. Mô hình ca sử dụng mức gộp ............................................................................... 73
3.1 Mô hình ca sử dụng mức gộp quản lý thông tin tuyển dụng nhân viên ...... 73
3.2 Mô hình ca sử dụng mức gộp quản lý Hợp đồng lao dộng ........................ 74
3.3 Mô hình ca sử dụng mức gộp quản lý Khen thưởng – Kỷ luật................... 75
3.4 Mô hình ca sử dụng mức gộp quản lý Quá trình đào tạo ........................... 75
3.5 Mô hình ca sử dụng mức gộp quản lý Lương ............................................ 76
IV. Mô tả chi tiết các ca sử dụng điển hình................................................................. 76
1.Ca sử dụng cập nhật danh mục công việc .............................................................. 76
2.Ca sử dụng cập nhật Hợp đồng lao động ............................................................... 79
2.1 Ca sử dụng thêm mới hợp đồng lao động .................................................. 80
2.2 Ca sử dụng sửa thông tin hợp đồng lao động ............................................ 81
2.3 Ca sử dụng xóa hợp đồng lao động ........................................................... 82
2.4 Ca sử dụng tìm kiếm hợp đồng lao động ................................................... 82
Luận văn thạc sĩ - 3 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
V. Phân tích hệ thống ............................................................................................... 83
1. Ca sử dụng cập nhật danh mục công việc ............................................................. 83
2. Ca sử dụng cập nhật Hợp đồng lao động .............................................................. 84
2.1 Mô hình khái niệm ................................................................................... 84
2.2 Biểu đồ tuần tự ......................................................................................... 86
VI. Biểu đồ lớp .......................................................................................................... 87
1. Biểu đồ lớp quản lý thông tin Tuyển dụng nhân viên ........................................... 87
2. Biểu đồ lớp quản lý Hợp đồng lao động ............................................................... 88
3. Biểu đồ lớp quản lý Quá trình công tác ................................................................ 89
4. Biểu đồ lớp quản lý Quá trình khen thưởng – kỷ luật ........................................... 90
5. Biểu đồ lớp quản lý Quá trình đào tạo .................................................................. 91
6. Biểu đồ lớp quản lý Lương .................................................................................. 92
VII. Thiết kế bảng thực thể dữ liệu .............................................................................. 93
VIII. Chương trình thử nghiệm ................................................................................... 116
KẾT LUẬN VÀ HƯỚNG PHÁT TRIỂN .................................................................. 118
TÀI LIỆU THAM KHẢO ......................................................................................... 121
Luận văn thạc sĩ - 4 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
DANH MỤC CÁC TỪ TIẾNG ANH VÀ VIẾT TẮT
Từ gốc Giải nghĩa
HTTT Hệ thông thông tin
ERP (Enterprise Resource Planning) Hoạch định nguồn lực doanh nghiệp
CSDL Cơ sở dữ liệu
CNTT Công nghệ thông tin
DANH MỤC CÁC BẢNG
Bảng 1: Đợt tuyển dụng - NS_UV_DotTuyendung .......................................................... 93
Bảng 2: Đề nghị tuyển dụng - NS_DeNghiTuyenDung .................................................... 93
Bảng 3: Vị trí tuyển dụng - NS_Vitri ............................................................................... 93
Bảng 4: Chi tiết đề nghị tuyển dụng - NS_DeNghiChiTiet ............................................... 94
Bảng 5: Hội đồng tuyển dụng - NS_Hoidong ................................................................... 94
Bảng 6: Chi tiết hội đồng - NS_ChiTietHoidong ............................................................. 94
Bảng 7: Kết quả phỏng vấn - Kiểm tra - NS_KetQuaPhongVan....................................... 94
Bảng 8: Hồ sơ dự tuyển - NS_UV_Hosotuyendung ......................................................... 95
Bảng 9: Bằng cấp của ứng viên - NS_UV_BangCap ........................................................ 95
Bảng 10: Quá trình làm việc của ứng viên - NS_UV_QuaTrinhLamViec ........................ 96
Bảng 11: Quá trình học tập của ứng viên - NS_UV_QuaTrinhHocTap ............................ 96
Bảng 12: Danh mục công ty thành viên/Chi nhánh - NS_DM_CongTy ............................ 96
Bảng 13: Danh mục bộ phận - NS_DM_Bophan ............................................................. 98
Bảng 14: Danh mục Chức danh - NS_DM_Chucdanh ..................................................... 98
Bảng 15 : Danh mục Chức vụ - NS_DM_Chucvu ............................................................ 98
Bảng 16: Danh mục Bằng cấp - NS_DM_Bangcap .......................................................... 98
Bảng 17: Danh mục Loại hợp đồng - NS_DM_Hopdong ................................................. 99
Bảng 18: Danh mục Lý do vắng mặt- NS_DM_LydoVang .............................................. 99
Bảng 19: Danh mục Ca làm việc - NS_DM_Ca ............................................................... 99
Bảng 20: Danh mục Bộ phận - NS_DM_BoPhan ............................................................. 99
Bảng 21: Thông tin nhân viên - NS_Nhanvien ............................................................... 100
Bảng 22: Hợp đồng lao động/Thử việc - NS_HopdongLD ............................................. 101
Bảng 23: Nhận xét thử việc - NS_NhanxetThuviec ........................................................ 101
Luận văn thạc sĩ - 5 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Bảng 24: Tạm hoãn hợp đồng - NS_TamhoanHDLD..................................................... 103
Bảng 25: Chấm dứt hợp đồng - NS_ChamdutHDLD ..................................................... 103
Bảng 26: Thông tin sức khỏe nhân viên - NS_SucKhoe ................................................. 103
Bảng 27: Thông tin quan hệ nhân viên - NS_QuanHe .................................................... 104
Bảng 28: Lý lịch làm việc nhân viên - NS_LylichLamviec ............................................ 104
Bảng 29: Quá trình làm việc nhân viên - NS_QuatrinhLamviec ..................................... 104
Bảng 30: Nghỉ phép năm nhân viên - NS_NghiphepNam .............................................. 105
Bảng 31: Nghỉ phép nhân viên - NS_Nghiphep ............................................................. 105
Bảng 32: Bảo hiểm Y tế nhân viên - NS_BHYT ............................................................ 105
Bảng 33: Bảo hiểm xã hội nhân viên - NS_BHXH ........................................................ 106
Bảng 34: Xếp ca nhân viên - NS_XepCa ....................................................................... 106
Bảng 35: Lương cơ bản - NS_LuongCoBan .................................................................. 106
Bảng 36: Bảng Hệ số lương - NS_BangHeSoLuong ...................................................... 107
Bảng 37: Bảng lương chi tiết - NS_BangLuongChitiet .................................................. 107
Bảng 38: Bảng chấm công - NS_BangChamCong ......................................................... 108
Bảng 39: Tạm ứng - NS_TamUng ................................................................................. 109
Bảng 40: Bảng mã chấm công - NS_MaChamcong ....................................................... 109
Bảng 41: Cách tính lương - NS_CachtinhLuong ............................................................ 109
Bảng 42: Bảng thuế thu nhập - NS_ThueThuNhap ........................................................ 111
Bảng 43: Ngày nghỉ - NS_NgayNghi............................................................................. 111
Bảng 44: Yêu cầu khen thưởng kỷ luật - NS_YeucauKTKL .......................................... 111
Bảng 45: Loại khen thưởng kỷ luật - NS_LoaiKTKL .................................................... 111
Bảng 46: Hội đồng khen thưởng kỷ luật - NS_HoidongKTKL ....................................... 112
Bảng 47: Chi tiết hội đồng khen thưởng kỷ luật - NS_ChitietHoidongKTKL ................ 112
Bảng 48: Kết luận khen thưởng kỷ luật - NS_KetluanKTKL ......................................... 112
Bảng 49: Danh mục dự án - NS_DM_DuAn .................................................................. 112
Bảng 50: Thành viên dự án - NS_ThanhvienDuAn ........................................................ 113
Bảng 51: Danh mục công việc - NS_DM_Congviec ...................................................... 113
Bảng 52: Quá trình công tác - NS_QuatrinhCongtac ...................................................... 113
Bảng 53: Yêu cầu đào tạo - NS_YeucauDaotao ............................................................. 113
Bảng 54: Khóa học - NS_KhoaHoc ............................................................................... 114
Bảng 55: Khóa học - NS_ChiTietKhoaHoc ................................................................... 114
Bảng 56: Phê duyệt khóa học - NS_PheDuyetKhoahoc ................................................. 115
Bảng 57: Qua trình đào tạo - NS_QuatrinhDaotao ......................................................... 115
Luận văn thạc sĩ - 6 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
DANH MỤC CÁC HÌNH, SƠ ĐỒ.
Hình 1: Biểu đồ hoạt động nghiệp vụ quản lý thông tin Tuyển dụng Nhân viên ................ 57
Hình 2: Biểu đồ hoạt động nghiệp vụ quản lý Hợp đồng lao động.................................... 60
Hình 3: Biểu đồ hoạt động nghiệp vụ quản lý Quá trình công tác ..................................... 62
Hình 4: Biểu đồ hoạt động nghiệp vụ quản lý Khen thưởng – Kỷ luật .............................. 63
Hình 5: Biểu đồ hoạt động nghiệp vụ quản lý Quá trình đào tạo ...................................... 66
Hình 6: Biểu đồ hoạt động nghiệp vụ quản lý Lương ....................................................... 68
Hình 7: Mô hình ca sử dụng mức gộp quản lý Tuyển dụng nhân viên .............................. 73
Hình 8: Mô hình ca sử dụng mức gộp quản lý Hợp đồng lao động ................................... 74
Hình 9: Mô hình ca sử dụng mức gộp quản lý Khen thưởng – Kỷ luật ............................. 75
Hình 10: Mô hình ca sử dụng mức gộp quản lý Quá trình đào tạo .................................... 75
Hình 11: Mô hình ca sử dụng mức gộp quản lý Lương .................................................... 76
Hình 12: Mô hình ca sử dụng mức gộp quản lý Công việc ............................................... 77
Hình 13: Mô tả chi tiết ca sử dụng cập nhật Hợp đồng lao động ...................................... 79
Hình 14: Sơ đồ liên kết ca sử dụng cập nhật danh mục Công việc .................................... 83
Hình 15: Biểu đồ tuần tự ca sử dụng cập nhật danh mục Công việc ................................. 83
Hình 16: Sơ đồ liên kết ca sử dụng cập nhật Hợp đồng lao động ...................................... 85
Hình 17: Biểu đồ tuần tự ca sử dụng cập nhật Hợp đồng lao động ................................... 86
Hình 18: Biểu đồ lớp quản lý thông tin tuyển dụng nhân viên .......................................... 87
Hình 19Biểu đồ lớp quản lý thông tin Hợp đồng lao động ............................................... 88
Hình 20: Biểu đồ lớp quản lý Quá trình công tác ............................................................. 89
Hình 21: Biểu đồ lớp quản lý Quá trình khen thưởng – kỷ luật ........................................ 90
Hình 22: Biểu đồ lớp quản lý Quá trình đào tạo ............................................................... 91
Hình 23: Biểu đồ lớp quản lý Lương ............................................................................... 92
Luận văn thạc sĩ - 7 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
MỞ ĐẦU
Mục tiêu, phạm vi của đề tài
Đề tài nghiên cứu, phân tích và thiết kế Hệ thống thông tin quản lý Nhân sự &
Lương trong Hệ thống hoạch định nguồn lực doanh nghiệp (Enterprise Resource
Planning - ERP) làm cơ sở cho việc xây dựng sản phẩm phần mềm ERP phục vụ,
hỗ trợ và hiện đại hoá công tác quản lý các hoạt động của doanh nghiệp.
ERP - Hoạch định nguồn lực doanh nghiệp (Enterprise resources Planning) là bộ
giải pháp công nghệ thông tin có khả năng tích hợp toàn bộ ứng dụng quản lí sản
xuất kinh doanh vào một hệ thống duy nhất, có thể tự động hoá các quy trình quản
lý, điều hành. Mọi hoạt động của doanh nghiệp, từ quản trị nguồn nhân lực, quản lý
dây chuyền sản xuất và cung ứng vật tư, quản lý tài chính nội bộ đến việc bán hàng,
tiếp thị sản phẩm, trao đổi với các đối tác, với khách hàng... đều được thực hiện trên
một hệ thống duy nhất.
Đặc trưng của phần mềm ERP là có cấu trúc phân hệ (module). Phần mềm có cấu
trúc phân hệ là một tập hợp gồm nhiều phần riêng lẻ, mỗi phần có một chức năng
riêng. Từng phân hệ có thể hoạt động độc lâp nhưng do bản chất của hệ thống ERP,
chúng kết nôi với nhau để tự động chia sẻ thông tin với các phân hệ khác nhau
nhằm tạo nên một hệ thống mạnh hơn.
Theo tài liệu chính thức của CIBRES, cơ quan tổ chức thi và cấp chứng chỉ CIERP
(Certified Implementer of ERP – Chứng chỉ chuyên viên triển khai hệ thống ERP)
thì một ERP tiêu chuẩn sẽ bao gồm các thành phần sau đây:
1. Kế toán tài chính
+ Sổ cái
+ Sổ phụ tiền mặt, sổ phụ ngân hàng
+ Bán hàng và các khoản phải thu
+ Mua hàng và các khoản phải trả
2. Nhân sự & Lương
3. Tài sản cố định
4. Hậu cần
+ Quản lý kho và tồn kho
+ Quản lý giao nhận
Luận văn thạc sĩ - 8 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
+ Quản lý nhà cung cấp
5. Sản xuất
+ Lập kế hoạch sản xuất
+ Lập kế hoạch nguyên vật liệu
+ Lập kế hoạch phân phối
+ Lập kế hoạch điều phối năng lực
+ Công thức sản phẩm
+ Quản lý luồng sản xuất
+ Quản lý mã vạch
+ Quản lý lệnh sản xuất
6. Dự báo và lập kế hoạch
7. Công cụ lập báo cáo
Như vậy, ERP là một tổ hợp các thành phần dành cho các phòng ban chức năng
trong một doanh nghiệp như kế toán, bán hàng, vật tư, sản xuất...
Một hệ thống ERP cụ thể có thể gồm không đầy đủ các thành phần trên. Nhưng,
như đã nói, "tích hợp" mới là điều chính yếu nhất của ERP. Tích hợp ở đây hiểu là
mọi phân hệ trong ERP cuối cùng đều đưa dữ liệu về một CSDL chung và duy nhất,
sau đó dữ liệu sẽ tự tìm đường đi để có mặt trong các bước xử lý tiếp theo ở những
bộ phận liên quan, cũng như trên các báo cáo tài chính và quản trị. Nói một cách
khác, không có dữ liệu nào cần phải nhập vào hai lần trong toàn bộ hệ thống này, là
điều khó tránh khi doanh nghiệp sử dụng nhiều hệ thống chức năng riêng rẽ trước
kia.
ERP giúp doanh nghiệp đánh giá được dịch vụ hoặc vùng tập trung nhiều khách
hàng, đánh giá dịch vụ khách hàng ưa thích sử dụng cũng như khách hàng tiềm
năng. Bên cạnh đó, ERP còn thể hiện nhiều lợi ích khác với tính năng tích hợp như:
Phát triển khả năng mua bán và đặt hàng cũng như đăng kí dịch vụ trên mạng; điều
phối toàn bộ giá cả cho các dự án; Theo dõi, quản lí và sử dụng các tài sản; Xác
định quyền hạn và trách nhiệm của từng người tham gia hệ thống ...
Như đã giới thiệu ở trên, ERP là một hệ thống quản lý bao trùm lên mọi hoạt động
của doanh nghiệp. Trong phạm vi đề tài này em chỉ tiến hành nghiên cứu, phân tích
và thiết kế một phần trong bài toán ERP đó là: Xây dựng hệ thống thông tin Quản
lý Nhân sự & Tiền lương trong hệ thống ERP .
Luận văn thạc sĩ - 9 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Luận văn thạc sĩ - 10 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
CHƯƠNG I:
HỆ THỐNG HOẠCH ĐỊNH NGUỒN LỰC DOANH NGHIỆP -
ERP VÀ CÁC VẤN ĐỀ ĐẶT RA
I. Khái niệm về ERP.
Hệ thống hoạch định Nguồn lực Doanh nghiệp - Enterprise Resource Planning
(ERP) là một thuật ngữ được dùng liên quan tới một loạt hoạt động của doanh
nghiệp, do phần mềm máy tính hỗ trợ , giúp doanh nghiệp quản lý một cách hiệu
quả các nguồn lực. Đồng thời quản lý, theo dõi và đánh giá các hoạt động trong
doanh nghiệp bao gồm: kế toán, phân tích tài chính, quản lý mua hàng, quản lý tồn
kho, hoạch định và quản lý sản xuát, quản lý hậu cần, quản lý quan hệ với khách
hàng, v.v... Mục tiêu tổng quát của hệ thống này là đảm bảo các nguồn lực thích
hợp của doanh nghiệp như nhân lực, vật tư, máy móc và tiền bạc có sẵn với số
lượng đủ khi cần, bằng cách sử dụng các công cụ hoạch định và lên kế hoạch.
Các nhà quản lý đã sớm nhận thấy máy tính không chỉ đơn thuần là một công cụ trợ
giúp nâng cao năng suất mà đã trở thành công cụ chủ đạo giúp doanh nghiệp tạo sự
chuyển biến triệt để trong cách làm việc, tiết kiệm chi phí, nâng cao chất lượng sản
phẩm cũng như cải thiện đáng kể mối quan hệ với khách hàng...
Từ những năm 60 đến nay, trên thế giới đã có nhiều hệ thống quản lý được áp dụng
cho các doanh nghiệp:
MRP – Material Requirement Planning – Hoạch định nhu cầu nguyên liệu
MRPII – Manufacturing Resource Planning – Hoạch định nguồn lực sản xuất
MES – Manufacturing Execution System – Hệ thống điều hành sản xuất
ERP – Enterprise Resource Planning – Hoạch định nguồn lực doanh nghiệp
ERM – Enterprise Resource Management – Quản trị nguồn lực doanh nghiệp
CRM – Client Relationship Management – Quản trị quan hệ khách hàng
SCM – Supply Chain Management – Quản trị dây chuyền cung cấp
Luận văn thạc sĩ - 11 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
MRP và MRPII: Hệ thống MRP được phát triển từ giữa những năm 60, đến giữa
những năm 70 thì chuyển qua hệ thống MRPII. MRP chủ yếu đưa ra các tính toán
về nguyên vật liệu cần thiết để hoàn thành kế hoạch sản xuất, MRPII chú trọng vào
khái niệm quản lý, bao gồm quản lý lao động và chi phí. Thời kỳ này các hệ thống
chạy trên các hệ thống máy lớn Mainframe và máy Mini.
ERP: Đến những năm 90, cùng với sự phát triển của công nghệ phần cứng và mạng
máy tính dựa trên cấu trúc Client – Server sử dụng máy chủ PC thay cho máy lớn
trở thành phổ biến, các hệ thống MRP nhường chỗ cho hệ thống mới là ERP. ERP
không chỉ giới hạn trong quản lý sản xuất mà còn bao trùm lên toàn bộ các hoạt
động chính của doanh nghiệp như: Kế toán, Quản trị nhân lực, Quản trị hậu cần,
Quản trị hệ thống bán hàng...
Thập kỷ 90 là thời kỳ hoàng kim của ERP tất cả các công ty đa quốc gia và đại đa
số các công ty tại các nước phát triển đều đã triển khai ERP. Đầu thế kỷ 21 thế giới
bắt đầu nói nhiều đến bước phát triển tiếp theo của ERP là ERM cùng các hệ thống
khác tận dụng tiến bộ của công nghệ Internet là CRM và SCM.
ERM: ERM tuy gần với ERP về cách viết nhưng là khái niệm rộng hơn, nó không
phải là một bước tiến hóa về chức năng hay kỹ thuật như MRP tiến hóa lên ERP,
ERM thực chất là một bộ công cụ quản lý doanh nghiệp mà phần mềm chỉ là một
bộ phận. Các công cụ khác có thể hoàn toàn mang tính quản lý như: Huấn luyện, Kỹ
thuật quản trị dự án... các yếu tố phi máy tính của ERM là điểm tiến hóa rất quan
trọng, nhiều dự án ERP không thành công là do thiếu yếu tố này.
CRM: Đặt trọng tâm vào khả năng giao tiếp với bên ngoài (Khách hàng, Nhà cung
cấp...) của một hệ thống quản lý. CRM quản lý từ phân tích thị trường, lập kế hoạch
tiếp thị và bán hàng đến các hoạt động tiếp thị như chiến dịch tiếp thị trực tiếp qua
Email, quản lý hoạt động chăm sóc khách hàng... CRM còn phân tích nhiều chiều
về khách hàng để giúp doanh nghiệp định hướng các hoạt động phát triển sản phẩm
và bán hàng.
SCM: Được định nghĩa là quá trình từ lập kế hoạch mua nguyên vật liệu, lựa chọn
nhà cung cấp, đưa ra các quy trình theo đó nhà cung cấp sẽ phải tuân thủ trong việc
cung cấp nguyên vật liệu cho doanh nghiệp, lập kế hoạch cho lượng hàng sản xuất,
Luận văn thạc sĩ - 12 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
quản lý quá trình giao hàng cho đến quản lý hàng trả lại và hỗ trợ khách hàng trong
việc nhận hàng.
Trong các hệ thống phần mềm quản lý nói trên, thì ERP là quan trọng nhất, đó là
xương sống của mọi hệ thống quản lý trong các công ty lớn trên thế giới. Tất cả các
công ty đa quốc gia hiện nay sẽ ngừng hoạt động nếu hệ thống ERP của họ bị trục
trặc vì bằng cách thủ công, công ty không thể kiểm soát được hàng trăm chi nhánh
và hàng triệu giao dịch diễn ra hàng ngày trên khắp thế giới. Với các công ty vừa và
nhỏ, ERP cũng là công cụ chính để họ tăng hiệu quả quản lý.
II. Hiện trạng ERP ở Việt Nam và những bất cập
ERP là sản phẩm của sự kết hợp giữa công nghệ thông tin cùng với bề dày kinh
nghiệm quản lý trong đó cho phép nhà quản lý tối ưu hoá quy trình hoạt động theo
hệ thống quản trị tiêu chuẩn quốc tế. Một hệ thống hoạt động mang tính mạng lưới,
do vậy yêu cầu người phát triển hệ thống phải có cái nhìn sâu rộng, tổng quát không
những về CNTT mà còn phải có tầm nhìn chiến lược trong quản lý.
Ở Việt Nam hiện còn tụt hậu khá xa trong tổ chức sản xuất, phân phối và triển khai
ERP. Số lượng các nhà sản xuất trong nước và nhập khẩu cũng đã đưa ra được sự
lựa chọn nhất định cho nhiều đối tượng khách hàng. Tuy nhiên, chưa hãng phần
mềm ERP của Việt Nam nào xây dựng được một hệ thống ERP mạnh và chuyên
nghiệp. Các công ty lớn trong nước cũng mới chỉ bắt đầu bắt tay vào xây dựng sản
phẩm. Các hãng phần mềm của Việt Nam chủ yếu làm đại lý Hệ thống phân phối
sản phẩm cho các hãng sản xuất ERP của nước ngoài, nên chỉ tác động được vào
một khoảng hẹp các khách hàng có vốn đầu tư nước ngoài.
Việc triển khai ERP cho các doanh nghiệp Việt Nam còn gặp rất nhiều khó khăn,
hầu hết các doanh nghiệp đều chưa triển khai ERP với nhiều lý do chủ quan và
khách quan sau:
+ Nhận thức: Các đối tượng triển khai ERP chủ yếu là các doanh nghiệp lớn, các
doanh nghiệp Việt Nam chưa có thói quen chi trả một số tiền lớn để mua một hệ
thống phần mềm quản lý các hoạt động của họ. Phần lớn chỉ dừng lại ở mức triển
khai một số phần mềm kế toán và một số phần mềm quản lý khác cho các bộ phận
Luận văn thạc sĩ - 13 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
trong công ty. Tuy nhiên những phần mềm này hoạt động đơn lẻ không chia sẻ
thông tin với nhau.
+ Quy trình quản lý: Để triển khai được hệ thống ERP đòi hỏi doanh nghiệp phải có
các quy trình chặt chẽ, khoa học trong mọi hoạt động. Muốn áp dụng được ERP
trước hết phải chuẩn hóa quy trình nghiệp vụ, hiện nay hầu hết các doanh nghiệp
Việt nam chưa có quy trình nghiệp vụ rõ ràng, cụ thể do đó không phải doanh
nghiệp nào cũng dùng được ERP. Những doanh nghiệp đã đạt chuẩn ISO về quy
trình quản lý sẽ dễ dàng hơn khi triển khai ERP.
+ Yêu cầu triển khai cao: ERP là một hệ thống phức tạp, do vậy khi triển khai phải
đảm bảo các điều kiện cần thiết như cơ cấu nhân sự bao gồm cả phía triển khai và
khách hàng, cán bộ tư vấn quản lý, tư vấn kỹ thuật, tư vấn hệ thống... Công việc
triển khai được chia làm nhiều giai đoạn: Phân tích và lập kế hoạch, thiết kế, chuyển
đổi dữ liệu, chạy thử, chuyển giao.
III. Lựa chọn phương pháp tiếp cận phát triển hệ thống ERP
Có hai cách tiếp cận cơ bản để phát triển phần mềm:
· Cách tiếp hướng chức năng và
· Cách tiếp cận hướng đối tượng.
1. Cách tiếp cận hướng chức năng
Phần lớn các chương trình được viết bằng ngôn ngữ lập trình như C, VB,
FoxPro hay Pascal từ trước đến nay đều được thực hiện theo cách tiếp cận hướng
chức năng hay còn được gọi là cách tiếp cận hướng thủ tục. Cách tiếp cận này có
những đặc trưng sau:
Dựa vào chức năng, nhiệm vụ là chính. Khi khảo sát, phân tích một hệ thống
chúng ta thường tập trung vào các nhiệm vụ mà nó cần thực hiện. Chúng ta tập
trung trước hết nghiên cứu các yêu cầu của bài toán để xác định các chức năng
chính của hệ thống. Do đó, hệ thống phần mềm được xem như là tập các chức năng,
nhiệm vụ cần tổ chức thực thi.
Phương pháp phân tích hệ thống có cấu trúc bắt nguồn vững chắc từ cách tiếp
cận hệ thống. Hệ thống được hoàn thiện theo cách phân tích top-down. Phân tích
hệ thống có cấu trúc không chỉ là “một ý tưởng tốt” hay một cái gì đó mà nhà thực
Luận văn thạc sĩ - 14 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
hành tìm ra để làm việc, nó còn là ứng dụng thực tế của một khái niệm lý thuyết đầy
hiệu lực.
Theo cách tiếp cận này, việc phân rã chức năng và làm mịn dần được thực
hiện theo cách từ trên xuống. Khả năng của con người là có giới hạn khi khảo sát,
nghiên cứu để hiểu và thực thi những gì mà hệ thống thực tế đòi hỏi. Để thống trị
(quản lý được) độ phức tạp của những vấn đề phức tạp trong thực tế thường chúng
ta phải sử dụng nguyên lý chia để trị, nghĩa là phân tách nhỏ các chức năng chính
thành các chức năng đơn giản hơn theo cách từ trên xuống. Quá trình này được lặp
lại cho đến khi thu được những đơn thể chức năng tương đối đơn giản, hiểu được và
thực hiện cài đặt chúng mà không làm tăng thêm độ phức tạp để liên kết chúng
trong hệ thống. Độ phức tạp liên kết các thành phần chức năng của hệ thống
thường là tỉ lệ nghịch với độ phức tạp của các đơn thể. Vì thế một vấn đề đặt ra là
có cách nào để biết khi nào quá trình phân tách các đơn thể chức năng hay còn gọi
là quá trình làm mịn dần này kết thúc. Thông thường thì quá trình thực hiện phân rã
các chức năng của hệ thống phụ thuộc nhiều vào độ phức hợp của bài toán ứng
dụng và vào trình độ của những người tham gia phát triển phần mềm. Một hệ thống
được phân tích dựa trên các chức năng hoặc quá trình sẽ được chia thành các hệ
thống con và tạo ra cấu trúc phân cấp các chức năng. Ví dụ, hệ thống quản lý thư
viện có thể phân chia từ trên xuống như sau:
Chúng ta có thể khẳng định là các chức năng của nhiều hệ thống thông tin quản lý
đều có thể tổ chức thành sơ đồ chức năng theo cấu trúc phân cấp có thứ bậc.
Các hoạt động trong quá trình phân tích HTTT được tiến hành theo một trình
tự khoa học, mang tính công nghệ cao. Trước hết phải có kế hoạch phân tích tỷ
mỷ, chu đáo đễn từng khâu công việc. Sau đó tiến hành từ bước phân tích chức
năng của HTTT, phân tích dòng thông tin nghiệp vụ và sau đó tiến hành mô hình
Hệ thống quản lý thư viện
1. Quản lý bạn đọc 2. Cho mượn tài liệu 3. Nhận trả tài liệu 4. Nhắc trả tài liệu
Luận văn thạc sĩ - 15 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
hoá HTTT bằng các mô hình như sơ đồ luồng dữ liệu, các ma trận phân tích phạm
vi, cân đối chức năng và dữ liệu. Cuối cùng là bản báo cáo chi tiết toàn bộ những
kết quả của quá trình phân tích hệ thống. Kết quả của giai đoạn phân tích sẽ là cơ
sở rất quan trọng để đưa ra quyết định có tiếp tục thiết kế hệ thống hay không. Và
nếu có thì tài liệu phân tích sẽ là nền tảng cơ bản để thiết kế hệ thống.
Quá trình phân tích thiết kế sử dụng một nhóm các công cụ, kĩ thuật và mô
hình để ghi nhận phân tích hệ thống hiện tại cũng như các yêu cầu mới của
người sử dụng, đồng thời xác định khuôn dạng mới của hệ thống tương lai.
Phân tích thiết kế hệ thống có cấu trúc có những quy tắc chung, chỉ ra những công
cụ sẽ được dùng ở từng giai đoạn của quá trình phát triển và quan hệ giữa chúng.
Mỗi quy tắc gồm một loạt các bước và giai đoạn, được hỗ trợ bởi các mẫu và các
bảng kiểm tra, sẽ áp đặt cách tiếp cận chuẩn hoá cho tiến trình phát triển. Giữa các
bước có sự phụ thuộc lẫn nhau, sản phẩm của bước này là đầu vào của bước tiếp
theo. Điều này làm cho hệ thống đáng tin cậy hơn.
Có sự tách bạch giữa mô hình vật lý và mô hình lôgic. Mô hình vật lý thường được
dùng để khảo sát hệ thống hiện tại và thiết kế hệ thống mới. Mô hình lôgic dùng cho
việc phân tích các yêu cầu của hệ thống.
Một điểm khá nổi bật là trong phương pháp phân tích có cấu trúc này đã ghi
nhận vai trò của người sử dụng trong các giai đoạn phát triển hệ thống.
Trong chu trình phát triển hệ thống, người sử dụng tham gia vào hầu hết các pha
trong vòng đời của mình, trừ pha mã hoá
Các giai đoạn thực hiện gần nhau trong quá trình phân tích thiết kế có thể tiến
hành gần như song song.
Mỗi giai đoạn có thể cung cấp những sửa đổi phù hợp cho một hoặc nhiều giai
đoạn trước đó.
Quá trình xây dựng một HTTT bao gồm nhiều giai đoạn, mỗi giai đoạn có một
nhiệm vụ cụ thể, giai đoạn sau dựa trên thành quả của giai đoạn trước, giai đoạn
trước tạo tiền đề cho giai đoạn sau. Do vậy, để đảm bảo cho quá trình thiết kế hệ
thống được hiệu quả thì người phải tuân theo nguyên tắc tuần tự, không được bỏ
Luận văn thạc sĩ - 16 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
qua bất cứ một giai đoạn nào. Đồng thời sau mỗi một giai đoạn, trên cơ sở phân tích
đánh giá bổ sung phương án được thiết kế, người ta có thể quay lại giai đoạn trước
đó để hoàn thiện thêm rồi mới chuyển sang thiết kế giai đoạn tiếp theo, theo cấu
trúc chu trình (lặp). Đây là một phương pháp khoa học làm cho quá trình thiết kế hệ
thống trở nên mềm dẻo, không cứng nhắc và mỗi giai đoạn đều được bổ sung hoàn
thiện thêm trong quy trình thiết kế.
Giảm được độ phức tạp khi phát triển hệ thống do được hỗ trợ bởi những tiến bộ
trong cả phần cứng và phần mềm. Chương trình được thể hiện dưới cùng dạng
ngôn ngữ thế hệ thứ tư (4GL) nên không cần những lập trình viên chuyên nghiệp.
Việc thiết kế kết hợp với các bản mẫu giúp cho người dùng sớm hình dung
được hệ thống mới, trong đó vai trò của người sử dụng được nhấn mạnh đặc biệt.
Người phát triển và khách hàng gặp nhau và xác định mục tiêu tổng thể cho phần
mềm, xác định các yêu cầu nào đã biết, miền nào cần khảo sát thêm. Rồi đến việc
thiết kế nhanh. Thiết kế nhanh tập trung vào việc biểu diễn các khía cạnh của phần
mềm thấy được đối với người dùng (cách đưa vào và định dạng đưa ra). Thiết kế
nhanh ® xây dựng một bản mẫu ® người dùng đánh giá ® làm mịn các yêu cầu
cho phần mềm. Tiến trình lặp đi lặp lại xảy ra để cho bản mẫu được “vi chỉnh” thoả
mãn yêu cầu của khách, đồng thời giúp người phát triển hiểu kỹ hơn cần phải thực
hiện nhu cầu nào
Các đơn thể chức năng trao đổi với nhau bằng cách truyền tham số hay sử
dụng dữ liệu chung. Một hệ thống phần mềm bao giờ cũng phải được xem như là
một thể thống nhất, do đó các đơn thể chức năng phải có quan hệ trao đổi thống tin,
dữ liệu với nhau. Trong một chương trình gồm nhiều hàm (thực hiện nhiều chức
Giai đoạn n
Giai đoạn n+1
Giai đoạn n+2
Luận văn thạc sĩ - 17 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
năng khác nhau) muốn trao đổi dữ liệu được với nhau thì nhất thiết phải sử dụng dữ
liệu liệu chung hoặc liên kết với nhau bằng cách truyền tham biến. Mỗi đơn thể
chức năng không những chỉ thao tác, xử lý trên những biến dữ liệu cục bộ mà còn
phải sử dụng các biến chung, thường đó là các biến toàn cục.
Với việc sử dụng những biến toàn cục thì những bất lợi trong quá trình thiết kế và
lập trình là khó tránh khỏi. Đối với những dự án lớn, phức tạp có nhiều nhóm
thamgia, mỗi nhóm chỉ đảm nhận một số chức năng nhất định và như thế khi một
nhóm có yêu cầu thay đổi về dữ liệu chung đó thì sẽ kéo theo tất cả các nhóm khác
có liên quan cũng phải thay đổi theo. Kết quả là khi có yêu cầu thay đổi của một
đơn thể chức năng sẽ ảnh hưởng tới các chức năng khác và do đó sẽ ảnh hưởng tới
hiệu xuất lao động của các nhóm cũng như của cả dự án. Mặt khác, các chức năng
của hệ thống có nhu cầu phải thay đổi là tất yếu và rất thường xuyên.
Tính mở và thích nghi của hệ thống được xây dựng theo cách tiếp cận này là thấp
vì:
Hệ thống được xây dựng dựa vào chức năng là chính mà trong thực tế thì chức
năng, nhiệm vụ của hệ thống lại hay thay đổi. Để đảm bảo cho hệ thống thực hiện
được công việc theo yêu cầu, nhất là những yêu cầu về mặt chức năng đó lại bị thay
đổi là công việc phức tạp và rất tốn kém. Ví dụ: giám đốc thư viện yêu cầu thay đổi
cách quản lý bạn đọc hoặc hơn nữa, yêu cầu bổ sung chức năng theo dõi những tài
liệu mới mà bạn đọc thường xuyên yêu cầu để đặt mua, v.v. Khi đó vấn đề duy trì
hệ thống phần mềm không phải là vấn đề dễ thực hiện. Nhiều khi có những yêu cầu
thay đổi cơ bản mà việc sửa đổi không hiệu quả và vì thế đòi hỏi phải thiết kế lại hệ
thống thì hiệu quả hơn.
Dữ liệu chung Dữ liệu chung
Chức năng 1 Chức năng 2
Dữ liệu riêng Dữ liệu riêng
Luận văn thạc sĩ - 18 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Các bộ phận của hệ thống phải sử dụng biến toàn cục để trao đổi với nhau, do vậy
khả năng thay đổi, mở rộng của chúng và của cả hệ thống là bị hạn chế. Như trên đã
phân tích, những thay đổi liên quan đến các dữ liệu chung sẽ ảnh hưởng tới các bộ
phận liên quan. Do đó, một thiết kế tốt phải rõ ràng, dễ hiểu và mọi sửa đổi chỉ có
hiệu ứng cục bộ.
Khả năng tái sử dụng bị hạn chế và không hỗ trợ cơ chế kế thừa. Để có độ thích
nghi cao thì mỗi thành phần phải là tự chứa. Muốn là tự chứa hoàn toàn thì một
thành phần không nên dùng các thành phần ngoại lai. Tuy nhiên, điều này lại mâu
thuẫn với kinh nghiệm nói rằng các thành phần hiện có nên là dùng lại được. Vậy là
cần có một sự cân bằng giữa tính ưu việt của sự dùng lại các thành phần (ở đây chủ
yếu là các hàm) và sự mất mát tính thích ứng được của chúng. Các thành của hệ
thống phải có tính cố kết nhưng phải tương đối lỏng để dễ thích nghi. Một trong cơ
chế chính hỗ trợ để dễ có được tính thích nghi là kế thừa thì cách tiếp cận hướng
chức năng lại không hỗ trợ. Đó là cơ chế biểu diễn tính tương tự của các thực thể,
đơn giản hoá định nghĩa những khái niệm tương tự từ những sự vật đã được định
nghĩa trước trên cơ sở bổ sung hay thay đổi một số các đặc trưng hay tính chất của
chúng. Cơ chế này giúp chúng ta thực hiện được nguyên lý tổng quát hoá và chi tiết
hoá các thành phần của hệ thống phần mềm.
2. Cách tiếp cận hướng đối tượng
Để khắc phục được những vấn đề tồn tại nêu trên thì chúng ta cần phải
nghiên cứu phương pháp, mô hình và công cụ mới, thích hợp cho việc phát triển
phần mềm đáp ứng các yêu cầu của khách hàng. Mô hình hướng đối tượng có thể
giúp chúng ta vượt được khủng hoảng trong công nghệ phần mềm và hy vọng sẽ
đưa ra được những sản phẩm phần mềm thương mại chất lượng cao: tin cậy, dễ mở
rộng, dễ thích nghi, cường tráng và phù hợp với yêu cầu của khách hàng. Cách tiếp
cận hướng đối tượng có những đặc trưng sau.
Đặt trọng tâm vào dữ liệu (thực thể). Khi khảo sát, phân tích một hệ thống chúng
ta không tập trung vào các nhiệm vụ như trước đây mà tìm hiểu xem nó gồm những
thực thể nào. Thực thể hay còn gọi là đối tượng, là những gì như người, vật, sự kiện,
v.v. mà chúng ta đang quan tâm, hay cần phải xử lý. Ví dụ, khi xây dựng “Hệ thống
Luận văn thạc sĩ - 19 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
quản lý thư viện” thì trước hết chúng ta tìm hiểu xem nó gồm những lớp đối tượng
hoặc những khái niệm nào.
Xem hệ thống như là tập các thực thể, các đối tượng. Để hiểu rõ về hệ thống,
chúng ta phân tách hệ thống thành các đơn thể đơn giản hơn. Quá trình này được
lặp lại cho đến khi thu được những đơn thể tương đối đơn giản, dễ hiểu và thực hiện
cài đặt chúng mà không làm tăng thêm độ phức tạp khi liên kết chúng trong hệ
thống. Xét “Hệ thống quản lý thư viện”, chúng ta có các lớp đối tượng sau:
Các lớp đối tượng trao đổi với nhau bằng các thông điệp. Theo nghĩa thông
thường thì lớp là nhóm một số người, vật có những đặc tính tương tự nhau hoặc có
những hành vi ứng xử giống nhau. Trong mô hình đối tượng, khái niệm lớp là cấu
trúc mô tả hợp nhất các thuộc tính, hay dữ liệu thành phần thể hiện các đặc tính của
mỗi đối tượng và các phương thức, hay hàm thành phần thao tác trên các dữ liệu
riêng và là giao diện trao đổi với các đối tượng khác để xác định hành vi của chúng
trong hệ thống. Khi có yêu cầu dữ liệu để thực hiện một nhiệm vụ nào đó, một đối
tượng sẽ gửi một thông điệp (gọi một phương thức) cho đối tượng khác. Đối tượng
nhận được thông điệp yêu cầu sẽ phải thực hiện một số công việc trên các dữ liệu
mà nó sẵn có hoặc lại tiếp tục yêu cầu những đối tượng khác hỗ trợ để có những
thông tin trả lời cho đối tượng yêu cầu. Với phương thức xử lý như thế thì một
chương trình hướng đối tượng thực sự có thể không cần sử dụng biến toàn cục nữa.
Tính mở và thích nghi của hệ thống cao hơn vì:
· Hệ thống được xây dựng dựa vào các lớp đối tượng nên khi có yêu cầu
thay đổi thì chỉ thay đổi những lớp đối tượng có liên quan hoặc bổ sung thêm
một số lớp đối tượng mới (có thể kế thừa từ những lớp có trước) để thực thi
những nhiệm vụ mới mà hệ thống cần thực hiện. Ví dụ: Giám đốc thư viện
yêu cầu bổ sung chức năng theo dõi những tài liệu mới mà bạn đọc thường
Tập_Danh_Mục Sách
Bạn_Đọc Tạp_Chí
Luận văn thạc sĩ - 20 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
xuyên yêu cầu để đặt mua, ta có thể bổ sung thêm lớp mới để theo dõi yêu
cầu: lớp Yêu_Cầu.
· Trong các chương trình hướng đối tượng có thể không cần sử dụng biến
toàn cục nên mọi sửa đổi, cập nhật trong mỗi thành phần chỉ có hiệu ứng cục
bộ.
Hỗ trợ sử dụng lại và cơ chế kế thừa. Các lớp đối tượng được tổ chức theo
nguyên lý bao gói và che giấu thông tin, điều này làm tăng thêm hiệu quả của kế
thừa và độ tin cậy của hệ thống. Các ngôn ngữ lập trình hướng đối tượng như: C++,
Java, C#, Delphi, v.v. đều hỗ trợ quan hệ kế thừa
3. So sánh sự giống và khác nhau của hai cách tiếp cận trong quá trình
phát triển phần mềm:
Phát triển phần mềm hướng đối tượng Phát triển phần mềm có cấu trúc
Lập trình
hướng đối
tượng
CSDL
Phân tích
Thiết kế
Lập trình
CSDL hướng
đối tượng
CSDL
Phân tích
Thiết kế
Lập trình
Lập trình
có cấu trúc
CSDL
quan hệ
Bước đệm
Bước đệm
Bước đệm
Luận văn thạc sĩ - 21 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4. Ưu điểm chính của phương pháp hướng đối tượng
· Đối tượng là cơ sở để kết hợp các đơn thể có thể sử dụng lại thành hệ
thống lớn hơn, tạo ra những sản phẩm có chất lượng cao.
· Qui ước truyền thông điệp giữa các đối tượng đảm bảo cho việc mô tả các
giao diện giữa các đối tượng thành phần bên trong hệ thống và những hệ
thống bên ngoài trở nên dễ dàng hơn. Điều đó giúp cho việc phân chia những
dự án lớn, phức tạp để phân tích, thiết kế theo cách chia nhỏ bài toán thành
các lớp đối tượng hoàn toàn tương ứng với quan điểm hướng tới lời giải phù
hợp với thế giới thực một các tự nhiên.
· Nguyên lý bao gói, che giấu thông tin hỗ trợ cho việc xây dựng những hệ
thống thông tin an toàn.
· Nguyên lý kế thừa dựa chính vào dữ liệu rất phù hợp với ngữ nghĩa của
mô hình trong cài đặt.
· Lập trình hướng đối tượng đặc biệt là kỹ thuật kế thừa cho phép dễ dàng
xác định các đơn thể và sử dụng ngay khi chúng chưa thực hiện đầy đủ các
chức năg (đơn thể mở) và sau đó mở rộng được mà không làm ảnh hưởng tới
các đơn thể khác.
· Định hướng đối tượng cung cấp những công cụ, môi trường mới, hiệu quả
để phát triển phần mềm theo hướng công nghiệp và hỗ trợ để tận dụng được
những khả năng kế thừa, sử dụng lại ở phạm vi diện rộng để xây dựng được
những hệ thống phức tạp, nhạy cảm như: hệ thống động, hệ thống thời gian
thực, v,v.
· Xoá bỏ được hố ngăn cách giữa các pha phân tích, thiết kế và cài đặt
trong quá trình xây dựng phần mềm.
Luận văn thạc sĩ - 22 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
5. Lựa chọn phương pháp tiếp cận để phát triển Hệ thống thông tin quản
trị nhân sự&Lương trong bài toán ERP.
Như đã trình bầy ở chương I, đặc trưng của ERP là có cấu trúc phân hệ (module).
Nó được cấu thành từ nhiều phần riêng lẻ, mỗi phần có một chức năng riêng và có
thể hoạt động độc lập. Nhưng tích hợp mới là đặc trưng nhất của ERP, tích hợp ở
đây được hiểu là:
· Tích hợp từ nhiều phân hệ (module)
· Tích hợp nhiều chức năng.
· Tích hợp cho nhiều mô hình quản lý của doanh nghiệp.
Khi triển khai, việc phải thay đổi lại cấu trúc, chức năng và các lựa chọn là không
thể tránh khỏi để phù hợp với từng doanh nghiệp cụ thể. Mặt khác khi xã hội ngày
càng phát triển thì các quan hệ lao động, cách thức quản lý cũng phải thay đổi để
phù hợp với yêu cầu, chính vì vậy những nhà phát triển ERP phải luôn luôn cải tiến
sản phẩm của mình sao cho hài lòng khách hàng.
Căn cứ vào các đặc điểm trên của ERP và các ưu điểm của phương pháp tiếp cận
hướng đối tượng nên em chọn phương pháp này cho để thực hiện luận văn này.
Luận văn thạc sĩ - 23 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
CHƯƠNG II:
QUY TRÌNH PHÂN TÍCH, THIẾT KẾ HƯỚNG ĐỐI TƯỢNG
I. Xây dụng mô hình nghiệp vụ
1. Mở đầu
Để nắm bắt được yêu cầu của một hệ thống tin học hóa, ta cần tìm hiểu hệ thống
thực. Công việc này được tiến hành bằng cách tìm hiểu hoạt động nghiệp vụ và xây
dựng các mô hình miền và mô hình nghiệp vụ để nắm bắt toàn bộ các vấn đề thuần
nghiệp vụ của hệ thống
2. Tìm hiểu nắm vững nghiệp vụ
Việc tìm hiểu nghiệp vụ được tiến hành qua các bước sau
· Tìm hiểu bối cảnh hệ thống
· Nắm bắt các yêu cầu phi chức năng
2.1 Tìm hiểu bối cảnh hệ thống
Mô tả bối cảnh của một hệ thống bằng cách xây dựng mô hình miền và mô hình
nghiệp vụ của nó. Tùy theo yêu cầu của từng bài toán cụ thể mà ta có thể xây dựng
một mô hình miền hoặc mô mô hình nghiệp vụ đầy đủ, hoặc cả hai hoặc không cần
mô hình nào cả
Xây dựng mô hình miền
Mục đich của mô hình hóa miền là để hiểu và mô tả các lớp quan trọng nhất bối
cảnh của miền. Ta có thể lập một từ điển giải thích để định nghĩa về các lớp miền.
Từ điển thuật ngữ và mô hình miền giúp khách hàng và người phát triển chia sẻ
những thuật ngữ khái niệm chung. Đối với những miền nghiệp vụ rất nhỏ, không
cần thiết phát triển một mô hình miền mà chỉ cần sử dụng từ điển thuật ngữ là đủ
Mô hình miền (domain model)
Mô hình miền mô tả các khái niệm quan trọng của hệ thống qua các đối tượng của
miền nghiệp vụ và liên kết giữa chúng với nhau. Các đối tượng miền là những vật
hay khái niệm trong thực tế hoặc các sự kiện diễn ra trong môi trường mà hệ thống
làm việc. Có 3 dạng lớp đối tượng miền điển hình
Luận văn thạc sĩ - 24 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
· Các đối tượng nghiệp vụ thể hiện những vật được quản lý trong hoạt động
nghiệp vụ như: bản yêu cầu nhân sự, tài khoản, hợp đồng ...
· Các đối tượng thế giới thực và các khái niệm mà một hệ thống cần theo
dõi, ví dụ như giao dịch thanh toán, mua hàng, rút tiền…
· Các sự kiện sẽ hoặc đã xuất hiện: Chấm công, phỏng vấn, ký hợp đồng
lao động …
· Mô hình miền có thể mô tả bằng nhiều biểu đồ lớp của UML
Xây dựng mô hình nghiệp vụ
Một mô hình nghiệp vụ được phát triển qua hai bước:
§ Xây dựng một mô hình ca sử dụng nghiệp vụ bao gồm việc xác định
các tác nhân nghiệp vụ mà các tác nhân sử dụng. Mô hình cho phép
người phát triển hiểu rõ hơn về giá trị mà nghiệp vụ đem lại cho tác
nhân sử dụng nó
§ Phát triển một mô hình đối tượng nghiệp vụ bao chứa những người
tham gia nghiệp vụ, các thực thể nghiệp vụ và các đơn vị công việc
cùng nhau thực hiện các ca sử dụng nghiệp vụ. Các quy tác nghiệp vụ
và các điều chình khác trong nghiệp vụ được liên kết với các đối
tượng khác
Mô hình nghiệp vụ (bussiness model)
Mô hình nghiệp vụ được thể hiện ra bằng một mô hình ca sử dụng nghiệp vụ. Nó có
thể bao gồm các chế tác(thành phần) sau:
§ Đối tượng miền
§ Đối tượng nghiệp vụ
§ Người tham gia nghiệp vụ và các trách nhiệm, thao tác tương ứng
Mô hình ca sử dụng nghiệp vụ
Mô hình ca sử dụng nghiệp vụ mô tả các quá trình nghiệp vụ của một tổ chức dưới
dạng các ca sử dụng nghiệp vụ và các tác nhân nghiệp vụ tương ứng. Nó xem xét
một hệ thống nghiệp vụ từ quan điểm người sử dụng và chỉ ra làm thế nào để hệ
thống cung cấp một giá trị gia tăng cho tác nhân nghiệp vụ hệ thống đó. Mô hình ca
sử dụng nghiệp vụ được miêu tả bằng sơ đồ ca sử dụng[3]
Luận văn thạc sĩ - 25 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Mô hình miền là một trường hợp riêng của mô hình nghiệp vụ mà ở đó ta chỉ tập
trung vào các vật – các lớp miền hoặc các thực thể nghiệp vụ mà người tham gia
nghiệp vụ sẽ phải làm với chúng
2.2. Xác định các yêu cầu bổ sung
Các yêu cầu bổ sung là các yêu cầu phi chức năng mà không thể liên kết với các ca
sử dụng nghiệp vụ cụ thể nào. Chúng có ảnh hưởng đến nhiều ca sử dụng hoặc chỉ
đến một ca sử dụng nghiệp vụ nào đó. Ví dụ như tính thể hiện, các giao diện, các
yêu cầu thiết kế vật lý và kiến trúc, các rằng buộc về thiết kế và cài đặt
II. Xác định yêu cầu
1. Mở đầu
Mục tiêu của việc xác định yêu cầu la phát triển một mô hình ca sử dụng của hệ
thống cần xây dựng bằng cách dùng các ca sử dụng. Các ca sử dụng cung cấp một
cách có hệ thống và trực quan để nắm bắt các yêu cầu có tính chức năng mà tập
trung đặc biệt vào giá trị gia tăng đem lại cho mỗi cá nhân người dùng hoặc mỗi hệ
thống bên ngoài tương tác với hệ thống
2. Luồng công việc xác định yêu cầu
Để mô tả các yêu cầu nghiệp vụ của hệ thống dưới góc độ phát triển phần mềm cần:
· Tìm các tác nhân và các ca sử dụng: nhằm đưa ra một phiên bản đầu tiên
của mô hình ca sử dụng.
· Xác định các ca sử dụng có ý nghĩa về mặt kiến trúc và sắp ưu tiên các ca
sử dụng sẽ được triển khai trong mỗi vòng lặp
· Mô tả chi tiết mọi ca sử dụng đã được sắp thứ tự ưu tiên
· Đưa ra các giao diện – người dùng thích hợp cho mỗi tác nhân tương tác
trong các ca sử dụng
· Tái cấu trúc mô hình ca sử dụng bằng cách xác định và đưa ra các tổng
quát hóa của các ca sử dụng để làm sao cho chúng càng dễ hiểu càng tốt
Kết quả của luồng công việc này là một phiên bản đầu tiên của mô hình ca sử dụng,
các ca sử dụng và các bản mẫu giao diện – người sử dụng đã được tổng hợp lại. Các
kết quả của các lần lặp tiếp theo sẽ gồm các phiên bản mới của các thành phần này
Luận văn thạc sĩ - 26 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
nhưng chúng sẽ được hoàn thiện, được cải tiến và làm mịn dần trong quá trình các
bước lặp
3. Tìm các tác nhân và các ca sử dụng
Việc xác định các ca sử dụng và các tác nhân gồm bốn bước:
§ Tìm các tác nhân
§ Tìm các ca sử dụng
§ Mô tả ngắn gọn mỗi ca sử dụng
§ Mô tả mô hình ca sử dụng tổng thể
Các bước này không bắt buộc phải thực hiện theo thứ tự mà thường được thực hiện
đồng thời. Kết quả của hoạt động này là một phiên bản của mô hình ca sử dụng với
các tác nhân và các ca sử dụng
3.1. Tìm các tác nhân
Có hai tiêu chuẩn để xác định các tác nhân:
§ Phải có ít nhất một người dùng mà có thể thực hiện vai trò của tác
nhân dự kiến
§ Sự trùng lặp giữa các vai trò của những tác nhân khác nhau đóng vai
trong mối quan hệ với hệ thống là tối thiểu nhất
Sau khi tìm được tác nhân cần:
Mô tả ngắn gọn các vai trò của mỗi tác nhân tương tác với hệ thống và mục tiêu sử
dụng hệ thống. Việc mô tả ngắn gọn mỗi tác nhân phải nêu bật được các yêu cầu và
các trách nhiệm của tác nhân đó
Các tác nhân nhận được ở đây có thể dùng làm điểm xuất phát để tìm các ca sử
dụng
Tác nhân (actor)
Tác nhân thể hiện cho những phần ngoài hệ thống mà tương tác với hệ thống. Tác
nhân có thể là các kiểu người dùng hoặc các kiểu hệ thống ngoài của hệ thống
Một tác nhân đóng một vai trò nào đó đối với mỗi ca sử dụng mà nó tương tác. Mỗi
khi một người dùng( hoặc hệ thống ngoài cụ thể) tương tác với hệ thống, thể hiện
của tác nhân tương ứng đóng một vai trò mà người dùng thực hiện
Luận văn thạc sĩ - 27 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2. Tìm các ca sử dụng
Từ danh sách các tác nhân, ta xác định các ca sử dụng mà mỗi tác nhân này thực
hiện. Khi xác định được đầy đủ và chính xác các tác nhân cũng như các ca sử dụng
mà các tác nhân này thực hiện để tương tác với hệ thống, ta sẽ có được các ca sử
dụng bao gói được toàn bộ các chức năng cần có của hệ thống
Khi xác định các ca sử dụng, nên áp dụng hai tiêu chuẩn sau:
Kết quả có giá trị: Mỗi ca sử dụng được thực hiện thành công phải cung cấp một giá
trị cho tác nhân để đạt được một mục tiêu nào đó khi tác nhân tương tác với hệ
thống.
Tác nhân cụ thể: Nhờ việc xác định các ca sử dụng mà chúng cung cấp giá trị cho
tác nhân người dùng thực. Các ca sử dụng không nên quá lớn
Ca sử dụng (use case)
Mỗi cách thức mà tác nhân sử dụng hệ thống được gọi là một ca sử dụng. Có thể coi
các ca sử dụng như là những “khúc” chức năng mà hệ thống cung cấp và đem lại
một giá trị gia tăng cho tác nhân. Nói một cách khác, mỗi ca sử dụng đặc tả một
chuỗi các hành động(kể cả các chuỗi hành động thay thế) mà hệ thống có thể thực
hiện khi tương tác với các tác nhân của nó. Một thể hiện ca sử dụng là sự thực
hiện(hoặc xử lý) của ca sử dụng đó
3.3. Mô tả ngắn gọn mỗi ca sử dụng
Sau khi tìm được các ca sử dụng, trước hết mô tả nó một cách ngắn gọn để tóm tắt
các hành động của ca sử dụng.
3.4. Mô tả Mô hình ca sử dụng tổng thể
Chúng ta sử dụng các biểu đồ và các các mô tả để diễn đạt mô hình ca sử dụng tổng
thể, đặc biệt là các ca sử dụng có liên quan đến nhau. Các ca sử dụng trong mô hình
ca sử dụng có thể được tổ chức thành các cụm ca sử dụng được gọi là các gói ca sử
dụng
Để đảm bảo tính nhất quán khi mô tả nhiều ca sử dụng cùng một lúc, ta nên xây
dựng từ điển giải thích, các thuật ngữ này có thể xuất phát từ các lớp trong mô hình
miền hoặc mô hình nghiệp vụ
Từ điển giải thích(glossary)
Luận văn thạc sĩ - 28 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Một từ điển giải thích thường được dùng để xác định các thuật ngữ quan trọng và
thông dụng mà người phát triển sử dụng để mô tả hệ thống. Một từ điển giải thích
đem lại sự thống nhất trong việc định nghĩa các khái niệm và các cách diễn đạt giữa
những người phát triển
Mô hình ca sử dụng
Một mô hình ca sử dụng là một mô hình của một hệ thống. Nó bao gồm các tác
nhân, các ca sử dụng và các mối quan hệ giữa chúng
Mô hình ca sử dụng cho phép những nhà phát triển và các khách hàng cùng làm
việc về các yêu cầu, đó là các điều kiện hoặc các khả năng mà hệ thống phải tuân
theo
Kết quả của bước này cũng là một mô tả tổng quan của mô hình ca sử dụng. Nó mô
tả các tác nhân và các ca sử dụng tương tác với nhau như thế nào, và các ca sử dụng
liên kết với nhau như thế nào.
Sau đó cần thẩm định mô hình ca sử dụng theo các tiêu chí sau:
§ Mọi yêu cầu cần thiết về mặt chức năng đã được nắm bắt thành các ca
sử dụng chưa?
§ Chuỗi các hành động đã la đúng đắn, đầy đủ và có thể hiểu được đối
với mỗi ca sử dụng chưa?
§ Bất kỳ các ca sử dụng nào đều phải cung cấp ít nhất một giá trị gia
tăng cho tác nhân. Nếu không thì các ca sử dụng này phải được xem
xét lại
4. Thứ tự ưu tiên các ca sử dụng
Mục đích hoạt động này là nhằm lập thứ tự ưu tiên các ca sử dụng để quyết định
những ca sử dụng nào cần được triển khai ngay trong những lần lặp đầu và chúng
đóng vai trò như kiến trúc của hệ thống
Mô tả kiến trúc
Mô tả kiến trúc la một cái nhìn về mặt kiến trúc của mô hình ca sử dụng. Nó gồm
những ca sử dụng mang ý nghĩa về mặt kiến trúc.
Một mô tả kiến trúc của một mô hình ca sử dụng thường bao gồm các ca sử dụng
mô tả một vài chức năng cốt yếu và quan trọng hoặc liên quan đến một vài yêu cầu
Luận văn thạc sĩ - 29 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
quan trọng mà cần được phát triển. Mô tả kiến trúc này thường được sử dụng như là
đầu vào để phân loại các ca sử dụng cho việc phát triển trong một vài bước lặp đầu
5. Mô tả chi tiết một ca sử dụng
Mục đích chính ở đây là mô tả luồng các sự kiện của ca sử dụng một cách chi tiết
khi khởi đông, tương tác với các tác nhân như thế nào đến kết thúc. Để mô tả chi
tiết ca sử dụng ta có thể mô tả bằng văn bản(hay bảng) và các biểu đồ ca sử dụng
kèm theo
Luồng các sự kiện của một ca sử dụng
Là luồng các sự kiện đặc tả chuỗi công việc mà hệ thống làm khi một ca sử dụng cụ
thể được thực hiện. Luồng các sự kiện cũng đặc tả cách thức mà hệ thống tương tác
với các tác nhân khi ca sử dụng được thực hiện. Nó có thể được mô tả dưới dạng
văn bản(hay bảng) chuỗi các hoạt động của một ca sử dụng
5.1. Cấu trúc của một Mô tả ca sử dụng
Cấu trúc của mô tả ca sử dụng thường được tổ chức sao cho cả người phát triển,
khách hàng, và người dùng đều có thể hiểu được. Mô tả ca sử dụng cần có cấu
trúc như sau:
§ Trạng thái xuất phát(tiền điều kiện)
§ Làm thế nào và khi nào thì ca sử dụng khởi động( tức là hành động
thứ nhất được thực hiện như thế nào)
§ Các chuỗi hành động phải được thực hiện theo thứ tự. Ở đây thứ tự
được xác định bởi chuỗi hành động đã đánh số
§ Ca sử dụng kết thúc như thế nào và khi nào
§ Trạng thái khi kết thúc(hậu điều kiện)
§ Các con đường không được phép thực hiện
§ Mô tả các con đường cơ bản(phương án) mà dãy hành động xảy ra
§ Mô tả các phương án ngoại lệ
Có thể mô tả mỗi phương án thực hiện ca sử dụng bằng văn bản( hay một bảng với
cột tác nhân và cột phản ứng của hệ thống)
Một nhiệm vụ quan trọng nữa là đặc tả là những yêu cầu phi chức năng. Đa số các
yêu cầu phi chức năng đều có liên quan tới một ca sử dụng cụ thể nào đó. Chẳng
hạn các yêu cầu về tốc độ thực hiện, tính khả dụng, độ chính xác, thời gian phúc
Luận văn thạc sĩ - 30 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
đáp, thời gian phục hồi. Các yêu cầu như vậy được gọi là các yêu cầu đặc biệt của
ca sử dụng đang xét. Ta có thể chuẩn bị chúng như một phần tài liệ của Mô tả ca sử
dụng
5.2. Hình thức hóa các Mô tả ca sử dụng
Đối với các ca sử dụng phức tạp, có nhiều trạng thái và sự chuyển tiếp, các mô tả ca
sử dụng bằng văn bản thương không đảm bảo tính chất nhất quán và làm cho người
phát triển khó hình dung. Do vậy, có thể mô tả cấu trúc đó bằng cách sử dụng các
biểu đồ có tính trực quan hơn
6. Tạo bản mẫu Giao diện người dùng
Bây giờ ta cần phác thảo các giao diện người dùng để giúp cho người thực hiện các
ca sử dụng một cách hiệu quả. Với mỗi ca sử dụng, ta cố gắng để nhận biết xem cái
gì là cần đối với các giao diện người dùng để tạo ra khả năng cho mỗi tác nhân dùng
các ca sử dụng. Công việc này gọi là thiết kế giao diện người dùng logic. Sau đó ta
tạo thiết kế giao diện người dùng thực và phát triển các bản mẫu để minh họa cách
thức mà các người dùng có thể dùng hệ thống để thực hiện các ca sử dụng
6.1. Tạo một thiết kế Giao diện người dùng Logic
Khi các tác nhân tương tác với hệ thống, tác nhân sẽ dùng và thao tác qua yếu tố
giao diện người dùng thể hiện cho các thuộc tính của các ca sử dụng. Ta sẽ xác định
và đặc tả các yếu tố này cho một tác nhân tại một thời điểm xác định bằng cách
duyệt qua mọi ca sử dụng mà tác nhân có thể truy nhập và xác định các yếu tố giao
diện người dùng tương ứng cho mỗi ca sử dụng
Để nhận được các yếu tố giao diện cho mỗi tác nhân cần xác định:
§ Yếu tố nào của giao diện người dùng cần có để dùng được các ca sử
dụng?
§ Các yêu tố này sẽ quan hệ với nhau như thế nào?
§ Chúng sẽ được sử dụng như thế nào trong các ca sử dụng khác nhau?
§ Dáng dấp của chúng là ra sao?
§ Chúng sẽ được điều khiển như thế nào?
Luận văn thạc sĩ - 31 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Để xác định những yếu tố giao diện – người dùng nào là cần có trong mỗi ca sử
dụng, chúng ta có thể trả lời các câu hỏi sau:
§ Cái nào trong số các lớp lĩnh vực, các thực thể nghiệp vụ, hoặc các
đơn vị công việc là thích hợp để làm các yếu tố giao diện – người
dùng cho ca sử dụng này?
§ Những yếu tố giao diện – người dùng nào mà tác nhân phải làm việc
với chúng
§ Những hành động nào mà tác nhân có thể gọi đến và những quyết
định nào mà tác nhân có thể tạo ra?
§ Hướng dẫn nào và thông tin nào mà tác nhân cần có trước khi gọi đến
mỗi hành động trong ca sử dụng
§ Thông tin gì mà tác nhân cần cung cấp cho hệ thống?
§ Thông tin gì mà hệ thống cần cung cấp cho tác nhận?
§ Các giá trị trung bình đối với mọi tham số đầu vào/ đầu ra là gì?
6.2. Tạo một thiết kế giao diện người dùng thực và làm bản mẫu
Trước tiên, ta chuẩn bị các phác thảo thô của chùm các yếu tố giao diện - người
dùng hình thành các giao diện người dùng có ích cho các tác nhân. Sau đó bổ sung
các yếu tố cần thiết để tổ hợp hàng yếu tố của giao diện – người dùng thành các
giao diện người dùng đầy đủ. Các yếu tố bổ sung này có thể bao gồm các bộ
chứa(container) các yếu tố giao diện – người dùng, các cửa sổ, các công cụ và các
điều khiển
Ta chuẩn bị xây dựng các bản mẫu có khả năng thi hành các chùm các yếu tố giao
diện – người dùng quan trọng nhất. Các bản mẫu này có thể được xây dựng bằng
một công cụ lập bản mẫu nhanh nào đó
Cuối cùng cần phải thẩm định giao diện người dùng thông qua các lần xét duyệt các
bản mẫu, các phác thảo và thực hiện càng sớm càng tốt để có thể tránh được những
sai sót
7. Cấu trúc mô hình ca sử dụng
Mục đích cấu trúc mô hình ca sử dụng là
Luận văn thạc sĩ - 32 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
· Tìm ra các mô tả chức năng có đặc tính chung hay được chia sẻ trong
nhiều ca sử dụng để tách ra mô tả riêng
· Tìm ra các chức năng phụ hoặc tùy chọn để mở rộng mô tả chức năng
thành các chức năng mới
7.1. Xác định các mô tả chức năng chung
Chúng ta cần tìm hành động hoặc các phần của các hành động mà là chung hoặc
được chia sẻ cho nhiều ca sử dụng. Phần chung này có thể được tách ra và được mô
tả trong một ca sử dụng riêng biệt. Ca sử dụng này được thể hiện bằng một sự tổng
quát hóa của các ca sử dụng đã có và là một ca sử dụng trừu tượng
Ca sử dụng “thực” là kết quả mà chúng ta nhận được sau khi áp dụng sự tổng hợp
hai ca sử dụng: một cụ thể, một trừu tượng. Ca sử dụng thực này trình bày hành vi
của thể hiện ca sử dụng mà một tác nhân nhận thức được khi tương tác với hệ thống
7.2. Xác định các mô tả chức năng bổ sung và tùy chọn
Một mối quan hệ mở rộng các ca sử dụng là một thể hiện sự mở rộng thêm một
chuỗi các hành động của một ca sử dụng. Một mối quan hệ mở rộng như là một các
được thêm vào trong mô tả của một ca sử dụng gốc. Các ca sử dụng “thực” có được
nhờ việc áp dụng các quan hệ tổng quát hóa và mở rộng đối với các ca sử dụng
trong mô hình. Các ca sử dụng thực mới đem lại giá trị cho người dùng
7.3. Xác định mối quan hệ khác giữa các ca sử dụng
Mối quan hệ bao gồm là mối quan hệ mở rộng đảo ngược, nó cung cấp các mở rộng
tường minh và vô điều kiện cho một ca sử dụng. Khi bao gồm một ca sử dụng, thì
chuỗi hành vi và các thuộc tính của ca sử dụng bị bao gồm đều được đóng gói và
không thể bị thay đổi hoặc truy nhập – chỉ có kết quả(hoặc chức năng) của ca sử
dụng bị bao gồm là có thể khai thác được, điều này là một điểm khác so với việc
dùng mối quan hệ tổng quát hóa
III. Phân tích
1. Mở đầu
Khi nắm bắt yêu cầu ta đã xác định các yêu cầu chức năng dưới dạng các ca sử
dụng và các yêu cầu phi chức năng dưới dạng các tài liệu bổ sung cho các mô tả ca
Luận văn thạc sĩ - 33 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
sử dụng. Tuy nhiên, hầu như vẫn còn các vấn đề tồn tại chưa được giải quyết về yêu
cầu của hệ thống. Để giải quyết các vấn đề tồn tại, ta cần phân tích các yêu cầu bằng
cách sử dụng ngôn ngữ của nhà phát triển để mô tả các kết quả nhận được và ta sẽ
nhận được một mô hình phân tích
Mô hình phân tích
Mô hình phân tích là một mô hình đối tượng khái niệm. Nó xác định các yêu cầu và
lập luận về cấu trúc nội tại của hệ thống. Mô hình phân tích được thể hiện ở mức
cao bằng một hệ thống các gói phân tích. Trong mô hình phân tích, các ca sử dụng
được thực thi bởi các lớp và các đối tượng phân tích
2. Luồng công việc phân tích
Để tạo ra mô hình phân tích cần tiến hành
§ Phân tích kiến trúc
§ Phân tích một ca sử dụng
§ Phân tích một lớp
§ Phân tích một gói
Trong quá trình phân tích, ta sẽ liên tục tìm các gói, các lớp phân tích mới và các
yêu cầu chung khi mô hình phân tích được tiếp tục làm mịn bằng cách phân rã các
gói phân tích và duy trì các gói đó
3. Phân tích kiến trúc
Mục đích của phân tích kiến trúc là phác họa những nét lớn của mô hình phân tích
thông qua việc xác định các gói phân tích, các lớp phân tích hiển nhiên, và các yêu
cầu chuyên biệt chung
3.1. Xác định các gói phân tích
Việc xác định các gói phân tích có thể được tiến hành một cách tự nhiên dựa trên
các yêu cầu chức năng và nghiệp vụ của bài toán được xet. Một cách trực tiếp để
xác định các gói phân tích là bố trí phần lớn các ca sử dụng vào một gói riêng rồi
sau đó tiến hành thực thi chức năng tương ứng bên trong gói đó
Gom các ca sử dụng vào một gói riêng thích hợp có thể dựa trên các tiêu chí sau:
§ Các ca sử dụng cần có để hỗ trợ một quá trình nghiệp vụ riêng
Luận văn thạc sĩ - 34 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
§ Các ca sử dụng cần có để hỗ trợ một tác nhân riêng của hệ thống
§ Các ca sử dụng có quan hệ với nhau thông qua các quan hệ tổng quát
hóa và mở rộng
Gói phân tích
Các gói phân tích cung cấp một phương tiện để tổ chức các chế tác của mô hình
phân tích thành các “cụm” nhỏ hơn và dễ quản lý. Một gói phân tích có thể chứa
đựng các lớp phân tích, các thực thi ca sử dụng và các gói phân tích khác
3.2. Xử lý phần chung của các gói phân tích
Trong nhiều trường hợp ta có thể tìm thấy các phần chung giữa các gói phân tích,
chẳng hạn: một lớp phân tích. Một cách thích hợp để xử lý vấn đề này là đặt phần
chung đó vào trong gói riêng nằm ngoài các gói chứa nó, rồi sau đó để các gói khác
có liên quan phụ thuộc vào gói chứa lớp chung này
Những lớp được chia sẻ có các phần chung như vậy thường là các lớp thực thể.
Chúng có thể được lần vết tới các lớp thực thể miền hoặc nghiệp vụ. Do vậy, ta nên
nghiên cứu các lớp thực thể miền hoặc lớp thực thể nghiệp vụ để tìm ra phần chung
và tạo nên các gói phân tích tổng quát ngay từ đầu
3.3. Xác định các gói dịch vụ
Việc xác định các dịch vụ thích hợp thường được tiến hành sau khi các yêu cầu
chức năng đã được hiểu rõ và đã xác định phần lớn các lớp phân tích. Các lớp phân
tích trong một gói dịch vụ cần đóng góp thực hiện cùng một dịch vụ
Để xác định các gói dịch vụ, ta có thể làm như sau
· Xác định một gói dịch vụ cho mỗi dịch vụ được chọn
· Xác định một gói dịch vụ cho mỗi dịch vụ mà có thể khiến dịch vụ đó trở
thành lựa chọn. Ta sẽ xác định một gói dịch vụ cho mỗi dịch vụ được cung
cấp bởi các lớp liên quan về mặt chức năng
Gói dịch vụ
Mỗi hệ thống cung cấp một tập hợp các dịch vụ cho khách hàng. Ta sử dụng khái
niệm gói dịch vụ để mô tả các gói được sử dụng ở một mức thấp hơn trong sơ đồ
Luận văn thạc sĩ - 35 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
phân cấp phân tích để cấu trúc hệ thống các dịch vụ mà nó cung cấp. Một gói dịch
vụ có thể có các tính chất sau:
§ Một gói dịch vụ chưa một tập hợp các lớp có liên quan với nhau về
mặt chức năng
§ Một gói dịch vụ là không thể chia nhỏ
§ Một hoặc nhiều gói dịch vụ có thể tham gia vào một thực thi ca sử
dụng và một gói dịch vụ có thể tham gia vào nhiều thực thi ca sử dụng
§ Một gói dịch vụ phụ thuộc rất ít vào các gói dịch vụ khác
§ Một gói dịch vụ thường liên quan đến chỉ một hoặc một vài tác nhân
§ Các chức năng mà một gói dịch vụ cung cấp có thể được quản lý như
một đơn vị riêng biệt
3.4. Xác định các mối quan hệ phụ thuộc giữa các gói phân tích
Mục tiêu ở đây là tìm ra các gói phân tích tương đối độc lập với các gói khác, tự
chúng được ghép nối lỏng lẻo với nhau nhưng có kết quả kết dính cao bên trọng.
Với mục tiêu trên ta cố gắng giảm số lượng các mối quan hệ giữa các lớp thuộc tính
các gói khác nhau. Cách tốt nhất để thực hiện công việc này là tổ chức mô hình
phân tích thành các tầng bằng cách ghép các gói ứng dụng cụ thể ở một tầng đỉnh và
các gói tổng quát hơn ở một tầng thấp hơn
3.5. Xác định các lớp thực thể hiển nhiên
Ta có thể xác định các lớp thực thể quan trọng nhất dựa trên các lớp miền hoặc các
thực thể nghiệp vụ đã được xác định trong quá trình nắm bắt các yêu cầu. Ở bước
này không nên xác định quá nhiều lớp và đi quá sâu vào chi tiết. Một phác thảo ban
đầu bao gồm các lớp có ý nghĩa về mặt kiến trúc là đủ
3.6. Xác định các yêu cầu đặc biệt chung
Một yêu cầu đặc biệt là một yêu cầu nảy sinh ra trong quá trình phân tích và việc
nắm bắt nó là quan trọng. Các yêu cầu kiểu này có thể là:
§ Tính lâu bền
§ Sự phân bố và tính tương tranh
§ Các điểm đặc trưng về an toàn
§ Dung sai về lỗi
Luận văn thạc sĩ - 36 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
§ Quản lý giao dịch
Các yêu cầu đặc biệt chung có thể được tham chiếu tới như là các yêu cầu đặc biệt
của các thực thi ca sử dụng cụ thể và các lớp phân tích
4. Phân tích một ca sử dụng
Việc phân tích một ca sử dụng nhằm:
· Xác định các lớp phân tích mà các đối tượng của nó cần thiết phải thực
hiện luồng các sự kiện của ca sử dụng
· Phân phối hành vi của ca sử dụng cho các đối tượng phân tích khi tương
tác với nhau
· Nắm bắt các yêu cầu đặc biệt để thực thi ca sử dụng
4.1. Xác định các lớp phân tích
Chúng ta sẽ xác định các lớp điều khiển, lớp thực thể, và lớp biên cần thiết để thực
thi ca sử dụng và phác thảo các tên gọi, các trách nhiệm, các thuộc tính và các mối
quan hệ của chúng
Một thực thi ca sử dụng phân tích là một sự cộng tác trong mô hình phân tích mô tả
làm thế nào một ca sử dụng cụ thể được thực hiện và thể hiện dưới dạng các lớp
phân tích và các đối tượng phân tích tương tác với nhau
Để xác định các lớp phân tích, ta làm mịn ca sử dụng dựa trên luồng các sự kiện mô
tả bằng văn bản – mô tả phân tích của thực thi ca sử dụng
Ta có thể xác định các lớp phân tích theo cách sau:
§ Xác định các thực thể bằng việc nghiên cứu mô tả ca sử dụng và bất
kỳ mô hình miền chi tiết nào đang có, sau đó xét xem thông tin nào
cần được đưa vào và cần thao tác trong thực thi ca sử dụng
§ Xác định một lớp biên trung tâm đối với mỗi tác nhân là người và
chọn lớp này làm cửa sổ co bản trong giao diện người sử dụng mà tác
nhân tương tác với nó. Nếu tác nhân đã tương tác với một lớp biên
nào đó, thì có thể dùng lại lớp này
§ Xác định một lớp biên nguyên thủy cho mỗi thực thể đã được tìm ra
lúc trước. Các lớp này đại diện cho các đối tượng logic tương tác với
tác nhân trong giao diện người dùng trong suốt một ca sử dụng
Luận văn thạc sĩ - 37 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
§ Xác định một lớp biên trung tâm cho mõi tác nhân hệ thống ngoài, và
chọn nó làm đại diện cho giao diện truyền thông
§ Xác định một lớp điều khiển chịu trách nhiệm quản lý việc điều khiển
và phối hợp thực thi ca sử dụng, sau đó làm mịnh lớp điều khiển này
theo các yêu cầu của ca sử dụng
Tập hợp các lớp phân tích tham gia một thực thi ca sử dụng vào một biểu đồ lớp và
sử dụng biểu đồ lớp nàu để chỉ ra các mối quan hệ được dùng trong việc thực thi ca
sử dụng
Lớp phân tích
Một lớp phân tích thể hiện cho một sự trừu tượng của một hoặc nhiều lớp và/hoặc
hệ thống con trong thiết kế hệ thống. Có ba kiểu lớp cơ bản sau: lớp biên, lớp điều
khiển, và lớp thực thể
Lớp biên
Một lớp biên thường được sử dụng để mô hình hóa tương tác giữa hệ thống
và các tác nhân của nó. Tương tác này bao gồm có việc nhận và hiển thị thông tin từ
các yêu cầu của người dùng và của các hệ thống ngoài. Mỗi lớp biên liên quan đến
ít nhất một tác nhân và ngược lại
Các lớp biên thường thể hiện như các trừu tượng hóa của các cửa
sổ(window), các biểu mẫu(form), các bảng hiển thị(pane), các giao diện truyền
thông(communication interface), giao diện máy in(printer interface), các bộ cảm
biến(sensor), các đầu cuối(terminal)…, nhưng ở một mức độ tương đối cao và mang
tính khái niệm chứ không đi quá sau vào chi tiết giao diện người dùng
Lớp thực thể
Một lớp thực thể được dùng để mô hình hóa các thông tin tồn tại lâu dài và
có thể được lưu trữ. Các lớp thực thể thường thể hiện các cấu trúc dữ liệu logic và
góp phần làm rõ về các thông tin nào mà hệ thống phải dựa vào
Lớp điều khiển
Các lớp điều khiển thể hiện sự phối hợp, sắp trình tự, các giao dịch, sự điều
khiển của các đối tượng và thường được sử dụng để bao gói các điều khiển liên
Luận văn thạc sĩ - 38 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
quan đến một ca sử dụng cụ thể. Các khía cạnh động của hệ thống được mô hình
hóa qua các lớp điều khiển
4.2. Mô tả các tương tác giữa các đối tượng phân tích
Khi đã có một phác thảo về các lớp phân tích cần thiết để thực thi các ca sử
dụng chúng ta cần phải mô tả cách thức mà các đối tượng phân tích tương tác với
nhau như thế nào. Việc này được tiến hành bằng cách sử dụng các biểu đồ cộng tác,
chúng chứa các thể hiện của tác nhân tham gia, các đối tượng phân tích, và các mối
liên kết giữa chúng. Nếu ca sử dụng có các luồng hoặc luồng con khác nhau và tách
biệt thì nên tạo một biểu đồ cộng tác riêng cho mỗi luồng
Một biểu đồ cộng tác xuất phát từ một điểm khởi đầu của luồng sự kiện ca sử
dụng sau đó di theo luồng từng bước và xác định xem đối tượng phân tích nào và
các tương tác của các thể hiện tác nhân nào là cần thiết để thực thi ca sử dụng đó.
Trong một biểu đồ cộng tác có các lưu ý sau:
§ Một ca sử dụng được gọi bằng một thông báo từ một tác nhân chuyển
tới một đối tượng biên
§ Mỗi lớp phân tích được xác định trong bước trước phải có ít nhất một
đối tượng phân tích tham gia trong một biểu đồ cộng tác
§ Các thông báo không được phép gán cho các tác vụ vì chúng ta không
đặc tả các tác vụ cho các lớp phân tích. Các kết nối trong biểu đồ là
các thể hiện của các liên kết giữa các lớp phân tích
§ Không tập trung chính vào sự tuần tự trong biểu đồ mà nên tập trung
vào các quan hệ(liên kết) giữa các đối tượng và các yêu cầu(như nắm
bắt trên các thông báo) về các đối tượng cụ thể
§ Biểu đồ cộng tác phải quản lý được mọi mối quan hệ của ca sử dụng
được thực thi
Trong một số trường hợp, có thể bổ sung các mô tả bằng văn bản cho các biểu đồ
cộng tác, đặc biệt nếu có nhiều biểu đồ thực thi cùng một ca sử dụng hoặc nếu có
các biểu đồ trình bày các luồng phức tạp
4.3. Nắm bắt các yêu cầu đặc biệt
Luận văn thạc sĩ - 39 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Ta cần nắm bắt các yêu cầu(phi chức năng) cần cho việc thực thi một ca sử
dụng mà đã được xác định trong phân tích nhưng phải được xử lý trong thiết kế và
thực thi
5. Phân tích một lớp
Mục đích của việc phân tích một lớp là:
· Xác định và duy trì các trách nhiệm của một lớp phân tích dựa trên vai trò
của nó trong các thực thi ca sử dụng
· Xác định và duy trì các thuộc tính và các mối quan hệ của lớp phân tích
· Nắm bắt các yêu cầu đặc biệt về việc thực thi của lớp phân tích
5.1. Xác định các trách nhiệm
Các trách nhiệm của một lớp có thể được xác định bằng cách tổ hợp mọi vai
trò mà lớp đó đảm nhận trong các thực thi ca sử dụng khác nhau. Ta có thể tìm thấy
mọi thực thi ca sử dụng mà lớp đó có tham gia, rút ra các trách nhiệm từ một vai trò
mỗi lần nó đóng, thêm các trách nhiệm bổ sung hoặc thay đổi các trách nhiệm đang
có dựa trên mỗi lần thực thi một ca sử dụng
5.2. Xác định các thuộc tính
Một thuộc tính đặc tả một tính chất của một lớp phân tích và nó thường được
gợi ý và đòi hỏi bởi các trách nhiệm của lớp của nó. Các hướng dẫn khi xác định
các thuộc tính
§ Tên của thuộc tính phải là một danh từ
§ Các kiểu của thuộc tính chỉ mang tính khai niệm trong phân tích,
chúng không bị hạn chế bởi môi trường thực thi. Khi chọn một kiểu
thuộc tính, nên dùng một kiểu đã có sẵn
§ Nếu một thể hiện thuộc tính đơn độc không thể chia sẻ cho nhiều đối
tượng phân tích thì bắt buộc xác định thuộc tính đó là một lớp riêng
§ Nếu một lớp phân tích trở nên quá phức tạp vì các thuộc tính của nó
thì có thể tách ra thành các lớp riêng
§ Các thuộc tính của các lớp thực thể thường là tương đối rõ ràng
§ Các thuộc tính của các lớp biên tương tác với các tác nhân bên ngoài
đại diện các hạng mục thông tin mà các tác nhân thao tác
Luận văn thạc sĩ - 40 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
§ Các thuộc tính của các lớp biên tương tác với các tác nhân hệ thống
ngoài của hệ thống thường đại diện các tính chất của một giao diện
truyền thông
§ Các lớp điều khiển có ít thuộc tính vì tuổi thọ của chúng ngắn. Tuy
nhiên, các lớp điều khiển có thể có các thuộc tính đại diện các giá trị
được tích lũy hoặc được dẫn xuất trong quá trình thực thi một ca sử
dụng
5.3. Xác định các liên kết và các kết hợp
Số lượng các mối quan hệ giữa các lớp phải được tối thiểu hóa. Trước hết
chúng không phải là các mối quan hệ ở thế giới thực mà là các mối quan hệ cần
phải tồn tại để đáp ứng lại các đòi hỏi từ các thực thi ca sử dụng khác nhau
Các kết hợp phải được dùng khi các đối tượng đại diện cho:
§ Các khái niệm mà về mặt vật lý là chứa đựng lẫn nhau, chẳng hạn oto
chưa người lái và khách hàng trong đó
§ Các khái niệm được tổng hợp từ nhau, chẳng hạn một ô tô gồm có
động cơ và các bánh xe
§ Các khái niệm mà chúng hình thành sau một sưu tập có tính khái niệm
về các đối tượng, như nhân sự bao gồm giám đốc, các trưởng bộ phận,
nhân viên …
5.4. Xác định các tổng quát hóa
Các tổng quát hóa được dùng trong quá trình phân tích để biểu diễn hành vi
chia sẻ và hành vi chung của các lớp phân tích khác nhau. Các tổng quát hóa phải
được giữ ở một mức cao và có tính khái niệm, chúng làm cho mô hình phân tích dễ
hiểu hơn
5.5. Nắm bắt các yêu cầu đặc biệt
Khi nắm bắt các yêu cầu này, hãy tham khảo bất kỳ các yêu cầu đặc biệt
chung nào đã được nhà kiến trúc xác định, nếu có thể
6. Phân tích một gói
Mục đích của việc phân tích một gói nhằm:
Luận văn thạc sĩ - 41 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
· Đảm bảo rằng gói phân tích càng độc lập đối với các gói khác càng tốt
· Đảm bảo rằng gói phân tích hoàn thành mục đích của nó là thực thi những
lớp miền hoặc các ca sử dụng nào đó
· Mô tả các mối quan hệ phụ thuộc sao cho hiệu ứng của các thay đổi sau
này có thể ước tính được
Một số nguyên tắc chung đối với hoạt động này:
· Xác định và duy trì các mối quan hệ phụ thuộc của gói này với các gói
khác mà các lớp được chưa trong các gói khác đó là được liên kết với gói
này
· Gói chứa các lớp đung. Hãy cố gắng làm cho gói trở thành kết dính bằng
cách chỉ đưa các đối tượng có liên quan về mặt chức năng vào trong gói
· Hạn chế các mối quan hệ phụ thuộc tới các gói khác. Bố trí lại các lớp chứa
trong một gói sang gói khác nếu nó quá phụ thuộc vào các gói khác
IV. Thiết kế
1. Mở đầu
Trong thiết kế, chúng ta định hình hệ thống và tìm hình thức biểu diễn nó để thực
hiện được mọi yêu cầu – kể cả các yêu cầu phi chức năng và các ràng buộc khác –
được đặt ra cho hệ thống đó. Một đầu vào cho thiết kế là mô hình phân tích. Khi
thiết kế sẽ cố gắng bảo tồn được càng nhiều càng tốt cấu trúc của hệ thống được
định hình từ mô hình phân tích. Kết quả của thiết kế là mô hình thiết kế. Nó là một
bản vẽ thiết kế của việc thực thi mô hình phân tích
Mô hình thiết kế
Mô hình thiết kế là một mô hình đối tượng mô tả sự thực thi các ca sử dụng
bằng cách tập trung vào việc xác định các yêu cầu chức năng và phi chức năng,
cũng như các rằng buộc khác liên quan đến môi trường triển khai và ảnh hưởng của
chúng lên hệ thống
§ Mô hình thiết kế bao gồm các yếu tố sau đây:
§ Các lớp thiết kế, bao gồm các lớp hoạt động, các tác vụ, các thuộc
tính, các mối quan hệ và các yêu cầu thực thi của chúng
§ Các thực thi ca sử dụng thiết kế. Chúng mô tả cách thức mà các ca sử
dụng được thiết kế dưới dạng những sự cộng tác bên trong mô hình
thiết kế
Luận văn thạc sĩ - 42 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
§ Khung nhìn kiến trúc của mô hình thiết kế, bao gồm các yếu tố quan
trọng về mặt kiến trúc
2. Luồng công việc thiết kế
Để nhận được mô hình thiết kế ta cần thực hiện các công việc sau:
· Thiết kế kiến trúc
· Thiết kế một ca sử dụng
· Thiết kế một lớp
· Thiết kế một hệ thống con
3. Thiết kế kiến trúc
Mục đích của thiết kế kiến trúc là phác họa các mô hình thiết kế và sự bố trí của
chúng bằng cách xác định:
· Các nút và các cấu hình mạng của hệ thống
· Các hệ thống con và các giao diện của chúng
· Các lớp thiết kế quan trọng về mặt kiến trúc
· Các cơ chế thiết kế chung để xử lý các yêu cầu chung
Các hệ thống con, các giao diện, hoặc các yếu tố thiết kế khác nhận được sẽ
được tích hợp vào trong mô hình thiết kế. Sau đó ta cần bảo trì, thẩm định lại và cập
nhật mô tả kiến trúc của các mô hình thiết kế và mô hình bố trí
Mô hình bố trí
Mô hình bố trí là một mô hình đối tượng mô tả sự phân bố về mặt vật lỹ của hệ
thống dưới dạng phân tán các chức năng trên các nút như thế nào. Mô hình bố trí
bao gồm:
§ Các nút, các đặc trưng, và các kết nối của chúng
§ Một sự sắp xếp ban đầu các lớp hoạt động trên các nút
Mỗi nút thể hiện cho một nguồn tài nguyên tính toán. Các nút có các mối quan hệ
với nhau thể hiện các phương tiện truyền thống giữa chúng
Mô hình bố trí có thể mô tả rất nhiều cấu hình mạng khác nhau. Chức năng của một
nút được xác định bởi các thành phần được triển khai trên các nút đó
Mô hình bố trí thể hiện một ánh xạ giữa kiến trúc phần mềm và kiến trúc hệ thống
Luận văn thạc sĩ - 43 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Xác định các nút và các cấu hình mạng
Các cấu hình mạng chung thường dùng một dạng mẫu hai/ba tầng trong đó các ứng
dụng khách hàng được phân vào một tâng, chức năng cơ sở dữ liệu vào một tầng, và
logic nghiệp vụ/ứng dụng vào một tầng. Dạng đơn giản của kiến trúc máy
khách/dịch vụ là một trường hợp đặc biệt của dạng mẫu ba tâng, trong đó logic
nghiệp vụ/ứng dụng được bố trí vào cùng trong một tầng
Những mặt khác nhau của các cấu hình mạng cần lưu ý bao gồm:
§ Những nút nào liên quan với nhau, các khả nang về công suất xử lý và
kích cỡ bộ nhớ của chúng là bao nhiêu?
§ Kết nối giữa các nút thuộc loại nào, các giao thức truyền thông giữa
chúng là gì?
§ Các đặc trưng của các kết nối và các giao thức truyền
§ Nhu cầu về khả năng xử lý dư thừa, về chế độ hỏng hóc, về sự di trú
tiến trình, về việc duy trì các bản sao dữ liệu dự phòng?
Xác định các hệ thống con và các giao diện của chúng
Các hệ thống con thiết kế cung cấp một cách thức để tổ chức mô hình thiết
kế thành các cụm có thể quản lý được. Chúng có thể được xác minh ngay từ đầu
như là một cách để phân chia công việc thiết kế hoặc được xác định khi mô hình
thiết kế tiến hóa và một cấu trúc lớn cần được phân rã ra
Việc đưa các hệ thống con như thế vào trong mô hình thiết kế cho phép có
thể lập luận và đánh giá các cơ hội tái sử dụng của chúng
Hệ thống con thiết kế
Một hệ thống con có thể bao gồm các lớp thiết kế, các thực thi ca sử dụng,
các giao diện và các hệ thống con. Ngoài ra, một hệ thống con có thể còn cung cấp
các giao diện thể hiện cho các chức năng xuất ra dưới dạng các tác vụ
Xác định các hệ thống con ứng dụng
Trước hết xác định các hệ thống con trong các tầng ứng dụng cụ thể và tầng
ứng dụng tổng quát
Luận văn thạc sĩ - 44 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Các gói phân tích đã được tìm thấy trong quá trình phân tích có thể được sử
dụng càng nhiều càng tốt để xác định các hệ thống con tương ứng bên trong mô
hình thiết kế. Điều này là đặc biệt quan trọng khi xảy ra đối với các gói dịch vụ,
giúp chúng ta xác định các hệ thống con dịch vụ tương ứng mà không phá vỡ cấu
trúc của hệ thống tùy theo dịch vụ mà hệ thống cung cấp. Tuy nhiên, việc xác định
ban đầu các hệ thống con này sẽ được tinh chế lại trong quá trình thiết kế. Việc
thẩm định sự phân rã hệ thống con ban đầu này có thể là cần thiết trong một số
trường hợp
Xác định các hệ thống con phần giữa và phần mềm hệ thống
Phần giữa và phần mềm hệ thống là nền móng của một hệ thống, vì mọi tính chức
năng đều ở đỉnh của phần mềm như là các hệ điều hành, các hệ quản trị cơ sở dữ
liệu, phần mềm truyền thống, các công nghệ phân tán đối tượng, các bộ dụng cụ
thiết kế GUI, và các công nghệ quản lý giao dịch
Xác định các mối quan hệ phụ thuộc giữa các hệ thống con
Các mối quan hệ phụ thuộc giữa các hệ thống con phải được xác định nếu
nội dung của chúng có các quan hệ lẫn nhau. Hướng của mối quan hệ phụ thuộc
phải là cùng hướng với hướng của mối quan hệ. Hãy xét các mối quan hệ phụ thuộc
giữa các gói phân tích tương ứng với các hệ thống con thiết kế
Xác định các giao diện của hệ thống con
Các giao diện được một hệ thống con cung cấp xác định các thao tác mà từ “bên
ngoài” hệ thống con đó có thể được truy nhập đến nó. Các giao diện này do các lớp
hoặc các hệ thống con khác bên trong hệ thống con đó cung cấp
Giao diện
Các giao diện được sử dụng để đặc tả các tác vụ mà các lớp thiết kế và các
hệ thống con cung cấp. Phần lớn các giao diện giữa các hệ thống con đều mang ý
nghĩa về mặt kiến trúc, xác định phạm vi và cách thức mà các hệ thống con được
phép tương tác với nhau
Một lớp thiết kế cung cấp một giao diện thì cũng phải cung cấp các phương
thức thực thi các tác vụ của giao diện đó. Một hệ thống con cung cấp một giao diện
Luận văn thạc sĩ - 45 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
thì phải chứa đựng các lớp thiết kế hoặc các hệ thống con khác cung cấp phương
thức thực thi giao diện đó
Xác định các lớp thiết kế quan trọng về mặt kiến trúc
Trong thực tế, ta sớm xác định các lớp thiết kế quan trọng về mặt kiến trúc
trong vòng đời của phần mềm để khởi đầu công việc thiết kế. Tuy nhiên, đa số các
lớp thiết kế sẽ được xác định khi thiết kế các lớp và được tinh chế lại dựa trên các
kết quả có được từ hoạt động thiết kế ca sử dụng
Mô tả kiến trúc thiết kế
Mô tả kiến trúc cho một mô hình thiết kế thường gồm:
Các hệ thống con, các giao diện và các phụ thuộc giữa chúng
Các lớp thiết kế cốt lõi, chẳng hạn như các lớp thiết kế mà lần vết tới các lớp phân
tích mang ý nghĩa kiến trúc, các lớp động, và các lớp thiết kế có tính chất tổng quát
và trung tâm, thể hiện cho các cơ chế thiết kế chung và có nhiều mối quan hệ với
các lớp thiết kế khác
Các thực thi ca sử dụng thiết kế để thực thi những chức năng cốt lõi và quan trọng
nhất cần được phát triển trong vòng đời phát triển, liên quan rất nhiều các lớp thiết
kế và có mức độ bao trùm lớm, qua nhiều hệ thống con khác nhau, hoặc liên quan
đến những lớp thiết kế cốt lõi
+ Xác định các lớp thiết kế từ các lớp phân tích
Lúc bắt đầu một số lớp thiết kế có thể được phác thảo từ các lớp phân tích quan
trọng về mặt kiến trúc đã xác định trong quá trình phân tích. Tương tự, các mối
quan hệ giữa các lớp phân tích này có thể được dùng để xác định các mối quan hệ
giữa các lớp thiết kế tương ứng
+ Xác định các lớp hoạt động
Ta cũng có thể xác định các lớp hoạt động do hệ thống yêu cầu bằng cách xem xét
các yêu cầu đồng thời đối với hệ thống, chẳng hạn như:
§ Các yêu cầu về hiệu năng, lưu lượng, và tính sẵn sàng mà các tác nhân cần
có khi chúng tương tác với hệ thống. Chẳng hạn, nếu một tác nhân nào đó
có các yêu cầu cao về thời gian phúc đáp, thì yêu cầu đó có thể được quản
Luận văn thạc sĩ - 46 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
lý bằng một đối tượng hoạt động dành riêng để nhận đầu vào từ tác nhân và
cung cấp đầu ra cho tác nhân đó – một đối tượng mà không bị dừng lại chỉ
vì các đối tượng hoạt động khác chịu tải nặng rồi
§ Sự phân bố hệ thống trên các nút. Các đối tượng hoạt động cần hỗ trợ bằng
sự phân bố trên nhiều nút khác nhau
§ Các yêu cầu khác như là các yêu cầu về sự khởi động và kết thúc hệ thống
Để phác thảo các lớp hoạt động ban đầu có thể sử dụng các kết quả của sự
phân tích mô hình bố trí làm đầu vào rồi sau đó bố trí các thiết kế tương ứng của các
lớp phân tích cho các nút thông qua các lớp hoạt động
Một khả năng khác để phác thảo các lớp hoạt động là sử dụng các hệ thống con
được xác định trước đó và phân toàn bộ một hệ thống con cho một nút riêng bằng
cách xác định một lớp hoạt động bên trong hệ thống con
Xác định các cơ chế thiết kế chung
Ta cần đưa ra một bộ các cơ chế thiết kế chung. Các cơ chế này có thể biểu thị là
các lớp thiết kế, các cộng tác, hoặc ngay cả các hệ thống con
Các yêu cầu cần phải xử lý thường có liên quan tới các vấn đề nhau sau:
§ Tính lâu bền
§ Phân bố đối tượng trong suốt
§ Các đặc trưng an toàn
§ Phát hiện lỗi và phục hồi
§ Quản lý giao dịch
Trong một số trường hợp, không thể tìm tháy cơ chế ngay nhưng thay vào đó lại tìm
được khi các thực thi ca sử dụng và các lớp thiết kế được khảo sát
Người phát triển cũng phải xác định các cộng tác chung mà chúng có thể làm việc
như là các dạng mẫu(pattern) và được sử dụng bởi nhiều thực thi ca sử dụng bên
trong mô hình thiết kế
4. Thiết kế một ca sử dụng
Mục tiêu của việc thiết kế một ca sử dụng là:
Luận văn thạc sĩ - 47 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
· Xác định các lớp thiết kế và/hoặc các hệ thống con mà các thể hiện của
chúng là cần thiết để thực hiện luồng các sự kiện của ca sử dụng đó
· Phân phối hành vi của ca sử dụng cho các đối tượng thiết kế tương tác
và/hoặc cho các hệ thống con tham gia
· Xác định các yêu cầu về các tác vụ của các lớp thiết kế và/hoặc các hệ
thống con và các giao diện của chúng
· Nắm bắt các yêu cầu triển khai cho ca sử dụng đó
Xác định các lớp thiết kế tham gia
Chúng ta xác định các lớp thiết kế cần thiết để thực thi ca sử dụng thiết kế như sau:
§ Nghiên cứu các lớp phân tích tham gia vào việc thực thi ca sử dụng
phân tích. Xác định các lớp thiết kế bằng cách lần vết tới các lớp phân
tích đó
§ Nghiên cứu các yêu cầu đặc biệt của việc thực thi ca sử dụng phân
tích tương ứng. Xác định các lớp thiết kế cần để thực thi các yêu cầu
đặc biệt đó
§ Nếu vẫn còn thiều một lớp thiết kế nào đó để thiết kế một ca sử dụng
cụ thể thì lớp được yêu cầu đó phải được xác định
Ta tập hợp các lớp thiết kế tham gia thực thi ca sử dụng vào một biểu đồ lớp. Sử
dụng biểu đồ này để chỉ ra các mối quan hệ đã được dùng trong việc thực thi ca sử
dụng này
Thực thi ca sử dụng thiết kế
Một thực thi ca sử dụng thiết kế là một sự cộng tác trong mô hình thiết kế miêu tả
làm thế nào một ca sử dụng cụ thể được thực thi và được thể hiện dưới dạng các lớp
thiết kế và các đối tượng của chúng. Một thực thi ca sử dụng thiết kế cung cấp một
“lần vết” tới một thực thi ca sử dụng phân tích trong mô hình phân tích, tức là lần
vết tới một ca sử dụng trong mô hình ca sử dụng
Một thực thi ca sử dụng thiết kế có thể mô tả bằng văn bản luồng các sự kiện, các
biểu đồ lớp với các lớp thiết kế tham gia, và các biểu đồ tương tác mô tả sự thực thi
của một luồng hoặc một kịch bản cụ thể của ca sử dụng dưới dạng tương tác giữa
các đối tượng thiết kế
Luận văn thạc sĩ - 48 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Một thực thi ca sử dụng thiết kế cung cấp một sự thực thi về mặt vật lý đối với một
thực thi ca sử dụng phân tích và nó cũng đồng thời quản lý phần lớn các yêu cầu phi
chức năng đã được nắm bát trong thực thi ca sử dụng phân tích
Mô tả các tương tác giữa các đối tượng thiết kế
Khi chúng ta đã có một phác thảo về các lớp thiết kế cần thiết để thực thi ca sử dụng,
ta cần phải mô tả cách thức mà các đối tượng thiết kế tương ứng tương tác với nhau.
Điều này được tiến hành bằng cách sử dụng các biểu đồ tuần tự chức các thể hiện
của tác nhân tham gia, các đối tượng thiết kế và sự truyền thông báo giữa chúng.
Nếu các ca sử dụng có các luồng hoặc luồng con khác nhau và tách biệt thì thường
phải tạo ra biểu đồ tuần tự cho mỗi luồng tách biệt đó
Trước hết, hãy nghiên cứ việc thực thi ca sử dụng phân tích tương ứng để đưa ra
một phác thảo về chuỗi các thông báo cần thiết giữa các đối tượng thiết kế. Trong
một số trường hợp, có thể chuyển trực tiếp một biểu đồ cộng tác thực thi ca sử dụng
phân tích thành một phác thảo ban đầu của một biểu đồ thiết kế tuần tự tương ứng
Khi chi tiết hóa các biểu đồ tương tác, phần lớn các trường hợp sẽ tìm ra các con
đường – phương án mới mà ca sử dụng đó có thể chọn. Những con đường như thế
có thể được mô tả bằng các nhãn của các biểu đồ hoặc trong chính các biểu đồ
tương tác của chúng. Khi đưa thêm thông tin mới vào, người phát triển thường phát
hiện ra các ngoại lệ mới mà đã bị bỏ qua trong quá trình nắm bắt hoặc phân tích các
yêu cầu.
Xác định các hệ thống con và các giao diện tham gia
Chúng ta đã thiết kế một ca sử dụng dướ dạng một sự cộng tác của các lớp và các
đối tượng của chúng. Tuy nhiên, đôi khi ta nên thiết kế một ca sử dụng dưới dạng
các hệ thống con tham gia và/hoặc các giao diện của chúng. Chẳng hạn, trong quá
trình phát triển từ trên xuống, cần phải nắm bắt các yêu cầu về các hệ thống con và
các giao diện của chúng trước khi thiết kế phần bên trong. Trong những trường hợp
như thế, một thực thi ca sử dụng thiết kế có thể được mô tả ở nhiều mức trong hệ
thống phân cấp các hệ thống con
Việc tìm ra các hệ thống con cần có để thực thi ca sử dụng có thể thực hiện bằng
cách lần vết tới các lớp phân tích tham gia và thực thi ca sử dụng phân tích tương
Luận văn thạc sĩ - 49 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
ứng. Xác định các gói phân tích mà chúng chứa các lớp phân tích đó, nếu có. Sau đó,
xác định các hệ thống con thiết kế mà chúng lần vết tới các gói phân tích đó.
Các hệ thống con có tham gia vào việc thực thi ca sử dụng được đưa vào một biểu
đồ lớp. Ta sẽ dùng biểu đồ lớp này để đưa ra các mối quan hệ phụ thuộc giữa các hệ
thống con đó và các giao diện bất kỳ mà đã được dùng trong việc thực thi ca sử
dụng
Mô tả các tương tác giữa các hệ thống con
Khi chúng ta có một phác thảo về các hệ thống con cần thiết để thực thi ca sử dụng,
chúng ta phải mô tả cách thức mà các đối tượng của các lớp trong chúng tương tác
trên một cấp độ của hệ thống. Việc này được tiến hành bằng cách sử dụng các biểu
đồ tuần tự chứa các thể hiện của tác nhân tham gia, các hệ thống con, và những sự
truyền thông báo giữa chúng
Nắm bắt các yêu cầu triển khai
Chúng ta nắm bắt mọi yêu cầu về thực thi một ca sử dụng, chẳng hạn, các yêu cầu
phi chức năng đã được xác định trong thiết kế nhưng sẽ phải được xử lý trong triển
khai
5. Thiết kế một lớp
Mục tiêu của việc thiết kế một lớp là tạo ra một lớp thiết kế sao cho hoàn thành vai
trò của nó trong các thực thi ca sử dụng và các yêu cầu phi chức năng được áp dụng
cho nó. Công việc này bao gồm việc bảo trì chính bản thân lớp thiết kế, và các mặt
sau đây của nó:
· Các tác vụ của nó
· Các thuộc tính của nó
· Các mối quan hệ mà nó tham gia vào đó
· Các phương pháp hóa học
· Các trạng thái được áp đặt cho nó
· Các mối quan hệ phụ thuộc của nó với bất kỳ các cơ chế thiết kế chung nào
· Các yêu cầu thích hợp cho việc thực thi của nó
· Sự thực thi đúng đắn của bất kỳ giao diện nào mà nó được yêu cầu cung
cấp
Phác thảo lớp thiết kế
Luận văn thạc sĩ - 50 - Nguyễn Chí Thành
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Trước hết, chúng ta cần phác thảo một hoặc nhiều lớp thiết kế dựa trên đầu vào là
các lớp phân tích và/hoặc các giao diện. Khi một giao diện được dùng làm đầu vào
thì vấn đề trở nên đơn giản và điều cần làm chỉ là gán một lớp thiết kế để cung cấp
giao diện đó
Khi sử dụng các lớp phân tích được cho làm đầu vào thì phương pháp được sử dụng
phụ thuộc vào khuôn mẫu của lớp phân tích:
§ Việc thiết kế của lớp biên phụ thuộc vào các công nghệ giao diện cụ thể nào
được sử dụng
§ Việc thiết kế các lớp thực thể biểu diễn các thông tin lâu dài thường kéo theo
việc sử dụng một công nghệ cơ sở dữ liệu riêng. Chẳng hạn, tạo ra các lớp
thiết kế được ánh xạ tương ứng thành các bản ghi trong một mô hình dữ liệu
quan hệ
§ Thiết kế các lớp điều khiển là việc làm tinh tế, vì chúng bao gói các chuỗi,
sự phù hợp của các đối tượng khác, và đôi khi có tính logic nghiệp vụ thuần
túy
Xác định các thao tác
Chúng ta xác định các tác vụ được cung cấp bởi lớp thiết kế và mô tả các tác vụ đó
bằng cách sử dụng cú pháp của ngôn ngữ lập trình. Các đầu vào quan trọng của
bước này là:
§ Các trách nhiệm của một lớp phân tích bất kỳ mà lớp thiết kế lần vết tới nó.
Một trách nhiệm thường chưa một hoặc nhiều tác vụ. Hơn nữa, nếu đã có mô
tả về đầu vào và đầu ra cho các trách nhiệm, ta có thể dùng chúng n
Các file đính kèm theo tài liệu này:
- ThSTN07.pdf