- Tìm hiểu được vai trò, ý nghĩa của ERP trong doanh nghiệp.
- Tìm hiểu được một giải pháp ERP trong thực tế là Adempiere.
- Xây đựng và triển khai được ứng dụng về quản lý hợp đồng trên hệ nguồn mở
Adempiere trong thực tế.
67 trang |
Chia sẻ: lylyngoc | Lượt xem: 2858 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Luận văn Ứng dụng erp adempiere trong quản lý hợp đồng, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
.................. 53
Phụ lục 02: Định nghĩa các cột bắt buộc có trong một table của hệ thống Adempiere. .... 55
Tài liệu tham khảo ..............................................................................................................
Danh sách các hình
Hình 1. Tổng quan hệ thống ERP và các thành phần chính ............................................... 3
Hình 2. Mô hình kiến trúc hệ thống Adempiere [8] ......................................................... 13
Hình 3. “Window, Tab & Field” của Adempiere ............................................................. 18
Hình 4. “Table & Column” của Adempiere..................................................................... 19
Hình 5. Tạo Menu của Adempiere .................................................................................. 20
Hình 6. Mô tả quy trình quản lý hợp đồng mua [4] ......................................................... 23
Hình 7. Mô hình Use Case mức cao-Quản lý hợp đồng mua [4]...................................... 24
Hình 8. Biểu đồ phân rã chức năng-Quản lý hợp đồng mua ............................................ 25
Hình 9. Mô hình ER-Quản lý hợp đồng mua ................................................................... 26
Hình 10. Tạo bảng VTT_BuyingContract ...................................................................... 28
Hình 11. Tạo cửa sổ “VTT Buying Contract” ................................................................. 29
Hình 12. Tạo tab VTT Buying Contract .......................................................................... 30
Hình 13. Tạo tab Payment Progress ................................................................................ 31
Hình 14. Tạo tab Supplying Product ............................................................................... 32
Hình 15. Tạo Menu “VTT Buying Contract” .................................................................. 33
Hình 16. Tạo mới các role xử lý workflow...................................................................... 34
Hình 17. Tạo workflow “Buying Contract” .................................................................... 35
Hình 18. Tạo node Start workflow “VTT Buying Contract” .......................................... 36
Hình 19. Tạo node Prepare workflow “VTT Buying Contract” ..................................... 37
Hình 20. Tạo node Approved workflow “VTT Buying Contract” .................................. 38
Hình 21. Tạo node Doc Complete workflow “VTT Buying Contract” ........................... 39
Hình 22. Tạo node Doc Auto workflow “VTT Buying Contract” ................................... 40
Hình 23. Tạo node Send Request workflow “VTT Buying Contract”.............................. 41
Hình 24. Tạo node Update Payment Progress ................................................................. 42
Hình 25. Tạo node Update Performance Progress ........................................................... 43
workflow “VTT Buying Contract” .................................................................................. 43
Hình 26. Hiển thị workflow “VTT Buying Contract” ...................................................... 44
Hình 27. Tạo Process cho workflow “VTT Buying Contract” ......................................... 45
Hình 28. Gắn process “Buying Contract Process” vào trường Doc Action ...................... 46
Hình 29. Mô tả quy trình quản lý hợp đồng bán [4] ........................................................ 47
Hình 30. Mô hình Use Case mức cao-Quản lý hợp đồng bán [4] ..................................... 48
Hình 31. Biểu đồ phân rã chức năng-Quản lý hợp đồng bán ........................................... 49
Hình 32. Mô hình ER-Quản lý hợp đồng bán .................................................................. 50
Bảng ký hiệu và chữ viết tắt
STT Ký hiệu viết tắt Viết đầy đủ
1 AD Adempiere
2 CNTT Công nghệ thông tin
3 ERP Enterprise Resource Planning
4 ER Entity Relationship
5 VTT Viettel Technology
1
Mở đầu
Trong vài năm trở lại đây, cùng với sự phát triển của CNTT, ERP đã nhanh chóng
trở thành giải pháp được nhiều công ty đầu tư thích đáng do những lợi ích to lớn mà nó
mang lại. ERP là một trong ba mũi nhọn có tính chất đột phá cho hướng đi của công nghệ
phần mềm Việt Nam. Với dự đoán về sự bùng nổ áp dụng ERP trong vòng hai tới ba năm
tới, đây sẽ là một thị trường lớn cho các doanh nghiệp phần mềm Việt Nam có sản phẩm
ERP.
Dựa vào nhu cầu về ứng dụng quản lý hợp đồng của công ty cổ phần công nghệ
Viettel (Viettel Technology), nội dung của khóa luận được hình thành và được tập trung
giải quyết.
Cấu trúc khóa luận gồm bốn chương:
Chương 1: Giới thiệu về ERP.
Chương 2: Phân hệ quản lý hợp đồng trong ERP và các yêu cầu của bài toán
quản lý hợp đồng ở Viettel Technology.
Chương 3: Kiến trúc hệ thống phần mềm nguồn mở ERP Adempiere
Chương 4: Phân tích và triển khai phân hệ quản lý hợp đồng trên Adempiere ở
Viettel Technology.
Phần Kết Luận tổng kết và tóm lược nội dung của khóa luận.
2
Chương 1: Giới thiệu về ERP
1.1 Khái niệm ERP
ERP là viết tắt của cụm từ “Enterprise Resource Planning” có thể dịch là “Hoạch
định tài nguyên doanh nghiệp”.Theo [1] ERP được định nghĩa là một hệ thống ứng dụng
đa phân hệ” (Multi Module Software Application) giúp tổ chức, doanh nghiệp quản lý các
nguồn lực và điều hành tác nghiệp . Bản chất ERP là một hệ thống tích hợp các phần mềm
ứng dụng đa phân hệ nhằm giúp tổ chức, doanh nghiệp quản lý các nguồn lực và tác
nghiệp. Giải pháp ERP cung cấp cho các nhà quản lý doanh nghiệp khả năng quản lý và
điều hành tài chính – kế toán, quản lý vật tư, quản lý sản xuất, quản lý kinh doanh và phân
phối sản phẩm, quản lý dự án, quản lý dịch vụ, quản lý khách hàng, quản lý nhân sự, các
công cụ dự báo và lập kế hoạch, báo cáo, .v.v. Thêm vào đó, như một đặc điểm rất quan
trọng mà các giải pháp ERP cung cấp cho các doanh nghiệp, là một hệ thống quản lý với
quy trình hiện đại theo chuẩn quốc tế, nhằm nâng cao khả năng quản lý điều hành doanh
nghiệp cho lãnh đạo cũng như tác nghiệp của các nhân viên.
3
1.2 Các thành phần chính của ERP
Một hệ thống ERP gồm năm thành phần chính được thể hiện trong hình
1.
Hình 1. Tổng quan hệ thống ERP và các thành phần chính
a. Quản lý nguồn lực tài chính (FRM-Finance Resource Management)
Là chức năng giúp doanh nghiệp theo dõi, quản lý được các nguồn lực tài chính, từ
đó đưa ra được các kế hoạch sản xuất kinh doanh phù hợp với tình hình tài chính của
doanh nghiệp.
b. Lập kế hoạch sản xuất (MRP-Manufacturing Resource Planning)
Đây là chức năng giúp nhà quản lý có thể lập kế hoạch sản xuất kinh doanh trước
cho doanh nghiệp dựa trên các nguồn lực tài chính, nhân lực…có sẵn nhằm tối ưu hóa các
nguồn lực này.
c. Quản lý quan hệ khách hàng (CRM-Customer Relationship Management)
Là chức năng giúp doanh nghiệp theo dõi, quản lý được thông tin về các đối tác,
khách hàng từ đó đưa ra những đối sách phù hợp với các đối tác, khách hàng này.
Hệ
thống
ERP
Quản lý
nguồn lực
tài chính
Quản lý
chuỗi
cung ứng
Quản lý
nhân sự
Lập kế
hoạch
sản xuất
Quản lý
quan hệ
khách
hàng
4
d. Quản lý chuỗi cung ứng (SCM-Supply Chain Management)
Là chức năng giúp doanh nghiệp tham gia vào quá trình mua bán.
e. Quản lý nhân sự (HRM-Human Resource Management)
Đây là một chức năng rất quan trọng, đảm bảo sử dụng nguồn nhân lực một cách
hiệu quả.
Trong mô hình ta thấy cả năm thành phần được tích hợp trong một hệ thống chung
là ERP System. Hệ thống ERP có tác dụng điều phối các hoạt động của cả năm thành
phần, mỗi thành phần có thể tương tác trực tiếp với ERP System hoặc có thể tương tác
gián tiếp với nhau thông qua một kênh chung là ERP System.
1.3 Các đặc điểm của ERP
Trong bài giới thiệu ERP của FAST [2] đã nêu năm đặc điểm của một hệ ERP do
Marcelino Tito Torres đưa ra:
- ERP là một hệ thống tích hợp quản trị sản xuất kinh doanh (Integrated Business
Operating System). Tích hợp-có nghĩa là mọi công đoạn, mọi người, mọi phòng ban chức
năng đều được liên kết, cộng tác với nhau trong một quá trình hoạt động sản xuất kinh
doanh thống nhất.
- ERP là một hệ thống do con người làm chủ với sự hỗ trợ của máy tính (People
System Supported by the Computer). Những cán bộ chức năng, nghiệp vụ mới là chính,
còn phần mềm và máy tính chỉ là hỗ trợ. Người sử dụng phải được đào tạo cẩn thận, tính
tích cực của từng nhân viên là các yếu tố quyết định.
- ERP là một hệ thống hoạt động theo quy tắc (Formal System), nghĩa là các hoạt
động phải tuân theo các quy tắc và các kế hoạch rõ ràng. Kế hoạch sản xuất kinh doanh
phải được lập ra theo năm, tháng, tuần; hệ thống sẽ không hoạt động khi không có kế
hoạch; các quy tắc, quy trình xử lý phải được quy định trước.
- ERP là hệ thống với các tránh nhiệm được xác định rõ (Defined Responsibilities).
Ai làm việc gì, trách nhiệm ra sao phải được xác định rõ trước.
- ERP là hệ thống liên kết giữa các phòng ban trong công ty (Communication among
Departments). Các phòng ban làm việc, trao đổi, cộng tác với nhau chứ không phải mỗi
phòng ban là một cát cứ.
5
ERP giúp loại bỏ các hệ thống phần mềm riêng lẻ ở các bộ phận trong một doanh
nghiệp: Tài chính, Nhân sự, Kinh Doanh, Sản xuất, Kho... và thay thế tất cả bằng một
chương trình phần mềm hợp nhất phân chia theo các phân hệ phần mềm khác nhau, tạo
nên một mối quan hệ thống nhất với nhau. Nhờ vậy kế toán có thể nhìn vào kho để xem
đơn hàng đã xuất cho khách hàng chưa. Phần mềm ERP rất linh động trong việc cài đặt
các phân hệ theo yêu cầu của doanh nghiệp. Các doanh nghiệp có thể yêu cầu cài đặt một
vài phân hệ mà doanh nghiệp cần, các phân hệ còn lại còn lại có thể cài đặt sau mà không
ảnh hưởng đến hệ thống. ERP còn có chế độ phân quyền người sử dụng linh động ngay
trên giao diện sử dụng người quản trị. Có chế độ bảo mật an toàn.
Những lợi ích của doanh nghiệp có được sau khi triển khai ERP:
- Loại bỏ các sai sót có thể xảy ra khi nhiều người cùng nhập một dữ liệu. Điều này
có thể hiểu được bởi khi áp dụng ERP thì cơ sở dữ liệu của tất cả các phòng ban trong
doanh nghiệp là chung, thống nhất với nhau. Việc hai người nhập cùng một dữ liệu nhưng
lại có sai lệch là không thể bởi các ràng buộc về dữ liệu.
- Tăng tốc độ dòng công việc. Không cần phải nói nhiều, rõ ràng tốc độ của một
nhân viên cầm chứng từ giấy chạy từ phòng này sang phòng khác không thể sánh với tốc
độ của chứng từ điện tử chạy trên mạng máy tính. ERP còn tăng tốc độ dòng công việc
bằng cách giải quyết các “nút cổ chai”. Giả sử một doanh nghiệp đã trang bị cục bộ được
các hệ thống phần mềm cho bộ phận kế toán và bán hàng, nhưng bộ phận kho chưa được
trang bị, thì bộ phận kho lúc này sẽ trở thành một “nút cổ chai” làm chậm lại năng suất
làm việc chung và bắt các bộ phận khác phải chờ. ERP với tính chất đồng bộ sẽ là công
cụ để giải quyết các “nút cổ chai” này.
Ngoài ra, nếu doanh nghiệp cần tính toán với dữ liệu, như từ đơn đặt hàng để tính ra
khối lượng nguyên vật liệu cần mua, hoặc đưa ra kế hoạch sản xuất tối ưu cho các đơn đặt
hàng, thì sẽ không có cách nào làm tay cho kịp nếu những tính toán này không được tích
hợp ngay trong hệ thống quản lý.
- Dữ liệu tập trung. Lợi ích của việc này rất rõ ràng, thay vì duy trì nhiều CSDL (cơ
sở dữ liệu) cục bộ với dữ liệu nhiều khi không trùng khớp, doanh nghiệp sẽ có một CSDL
thống nhất và tập trung. Một ví dụ dễ thấy của CSDL tập trung là cho phép thường xuyên
đưa ra các báo cáo chính xác và kịp thời cho lãnh đạo, khắc phục tình trạng chung trong
các doanh nghiệp, nhất là doanh nghiệp lớn và phức tạp như các công ty sản xuất lớn, các
6
tổng công ty, là chỉ có thể ra được báo cáo tài chính vài lần trong một năm và số liệu
thường chậm so với thực tế nhiều tuần hoặc thậm chí nhiều tháng.
Dữ liệu tập trung còn là tiền đề đầu tiên cho việc phân tích các dữ liệu theo nhiều
góc khác nhau (Data Mining), nhằm đưa ra những báo cáo mang tính trợ giúp quyết định
kinh doanh.
- Dễ dàng kiểm soát một CSDL và các quy trình nghiệp vụ tập trung sẽ giúp bạn
lãnh đạo dễ dàng áp dụng các cơ chế kiểm soát nội bộ. Chức năng “tìm vết” (Audit Track)
của hệ thống ERP cho phép nhanh chóng tìm ra nguồn gốc những bút toán cần kiểm tra,
cũng như những nhân viên liên quan đến đường đi của bút toán đó.
Tuy nhiên việc triển khai một hệ thống ERP cũng có những hạn chế nhất định
như:
- Chi phí triển khai ban đầu cao do phải đầu tư về phần cứng và hạ tầng, bản quyền
phần mềm ERP (với phần mềm ERP nguồn mở thì không cần mất kinh phí cho việc mua
bản quyền) và kinh phí dịch vụ triển khai. Trong ba cấu phần này thì kinh phí dịch vụ
triển khai chiếm nhiều nhất.
- Về thời gian triển khai, khá nhiều dự án ERP bị trễ hạn nghiệm thu do doanh
nghiệp không tập trung nguồn lực và không lường trước được sự phức tạp khi triển khai
hệ thống.
Việc triển khai ban đầu gặp vô vàn khó khăn nhiều khi dẫn đến sự đổ vỡ dự án, đi
sâu hơn nữa vào một quy trình nghiệp vụ điển hình của ERP thì nó không cho phép ta sửa
trực tiếp một lỗi nhập sai như các phần mềm kế toán thông thường khác mà nó yêu cầu
phải nhập vào một phép tính bù trừ so với lỗi sai đó.
- Về yếu tố con người, sự khó khăn tiên quyết khi áp dụng sơ khai ERP chính là thái
độ và sự nhìn nhận đúng đắn của lãnh đạo doanh nghiệp, đó là người có ảnh hưởng rất lớn
đến hiệu quả của dự án này, kế đến là việc nhận thức chưa đúng mức về ERP của cán bộ
nhân viên khác, trình độ tin học của mỗi người là khác nhau, sự chấp nhận thay đổi so với
cái cũ của mỗi người là khác nhau.
7
Chương 2: Phân hệ quản lý hợp đồng trong ERP và các yêu
của bài toán quản lý hợp đồng ở Viettel Technology
Quản lý hợp đồng là một phân hệ nằm trong thành phần quản lý chuỗi cung ứng của
hệ thống ERP. Quản lý hợp đồng là một phần quan trọng trong tổng thể của hệ thống
ERP, nó có chức năng như là xương sống đảm bảo cho mọi hoạt động sản xuất kinh
doanh của một doanh nghiệp.
2.1 Nhu cầu và ý nghĩa của việc quản lý hợp đồng
Trong hoạt động sản xuất kinh doanh, mỗi một doanh nghiệp đều thường xuyên phải
thực hiện các hoạt động thương mại dưới dạng các hợp đồng mua và bán. Các hợp đồng
mua/bán thường được thực hiện bởi một đơn vị nhưng lại có liên quan đến rất nhiều
phòng ban (tài chính, nhân sự, kế hoạch, kho…), và nhiều khâu quản lý trong doanh
nghiệp (sản xuất, bán hàng, quan hệ khách hàng…). Vì vậy, trong khi thực hiện hợp đồng
sẽ có thể nảy sinh các vấn đề như: sự không thống nhất giữa các phòng ban về tiến độ
thực hiện, thanh toán hợp đồng…; nảy sinh mâu thuẫn với khách hàng, đối tác trong việc
thực thi hợp đồng… Bài toán về quản lý các hợp đồng mua/bán được đặt ra.
Về mặt ý nghĩa, quản lý hợp đồng nhằm mục đích đảm bảo quá trình thực hiện hợp
đồng được diễn ra thống nhất, đảm bảo hợp đồng được thực hiện đúng như đã ký kết,
giảm thiểu các thiệt hại trong trường hợp phát sinh tranh chấp và có cơ sở để buộc các
bên thực hiện đúng trách nhiệm của mình trong hợp đồng.
Hơn nữa, việc quản lý tốt được các hợp đồng mua/bán, sẽ có tác động tích cực tới
các khâu quản lý khác trong doanh nghiệp như hoạt động sản xuất, kinh doanh, tài chính,
quan hệ khách hàng…
2.2 Yêu cầu bài toán về quản lý hợp đồng ở Công ty Viettel Technology
- Công ty cổ phần công nghệ Viettel (Viettel Technology) là một công ty con trực
thuộc Tập đoàn viễn thông quân đội Viettel, với các lĩnh vực hoạt động cụ thể là:
+ Cung cấp các giải pháp tích hợp hệ thống ICT (Information and communication
technologies) cho Tập đoàn Viettel và các doanh nghiệp bên ngoài theo hướng giải pháp
doanh nghiệp.
8
+ Tư vấn thiết kế và giải pháp tự động hoá toà nhà.
+ Quản lý dịch vụ thuê (Managed Service).
+ Cung cấp các dịch vụ tư vấn về tối ưu hóa mạng lưới, quy hoạch mạng lưới và
công nghệ.
+ Phát triển và cung cấp phần mềm.
+ Sản xuất và cung cấp thiết bị phần cứng.
- Là một đơn vị trực tiếp sản xuất kinh doanh trong lĩnh vực công nghệ, Viettel
Technology cũng giống như các doanh nghiệp khác, hoạt động sản xuất kinh doanh luôn
gắn liền với các hoạt động mua và bán. Vì vậy, bên cạnh việc quản lý các hoạt động sản
xuất, kinh doanh, tài chính…công ty cũng thấy được sự cần thiết của việc quản lý hợp
đồng.
Theo tài liệu đặc tả yêu cầu người dùng dự án ERP-VTT [4] các yêu cầu chức năng
của bài toán về quản lý hợp đồng của công ty được khảo sát và mô tả như dưới đây:
2.2.1 Yêu cầu chức năng quản lý hợp đồng mua
- :
Thông tin chung về hợp đồng
Thông tin về tiến độ thực hiện hợp đồng
Thông tin về tiến độ thanh toán
- Các thông tin quản lý chung về hợp đồng:
Theo tờ trình
Số hiệu hợp đồng
Ngày ký hợp đồng
Đối tác cung cấp. Theo dạng danh mục, đối tác có các thông tin sau:
o Tên
o Địa chỉ
o Số điện thoại
o Mã số thuế
o Tài khoản
o Mở tại
9
o Đại diện
o Chức vụ
Mặt hàng cung cấp
o Số thứ tự
o Mô tả thiết bị
o Đơn giá (VNĐ)
o Số lượng
o Thành tiền (VNĐ)
o Bảo hành (Tháng)
Trách nhiệm của các bên
o Trách nhiệm bên A
o Trách nhiệm bên B
Ngiệm thu và bàn giao hàng hóa
o Thời gian cung cấp và bàn giao
o Địa điểm bàn giao
o Nghiệm thu sản phẩm
Tổng giá trị hợp đồng và phương thức thanh toán
o Tổng giá trị hợp đồng
o Đơn vị tiền
o Hình thức hợp đồng
o Hình thức thanh toán
Thanh toán L/C (Letter of Credit)
Thanh toán trực tiếp
Tệp tin đính kèm
Ghi chú
- Các thông tin về tiến độ thực hiện hợp đồng:
Biên bản bàn giao và nghiệm thu
o Số biên bản
o Theo hợp đồng số
o Ngày bàn giao và nghiệm thu
o Đại diện bên A
Tên
10
Chức vụ
o Đại diện bên B
Tên
Chức vụ
o Nội dung bàn giao và nghiệm thu
Số thứ tự
Mô tả sản phẩm
Số lượng
Số máy
o Chất lượng
o Kết luận
Biên bản thanh lý
o Số
o Theo hợp đồng số
o Theo biên bản nghiệm thu số
o Theo hóa đơn số
o Ngày
o Giá trị
o Khối lượng
- Các thông tin về tiến độ thanh toán:
Tiến độ thanh toán
o Giai đoạn
o Thời gian dự kiến
o Số tiền dự kiến
o Thời gian phải trả
o Số tiền phải trả
o Thời gian đã trả
o Số tiền đã trả
o Số hóa đơn chứng từ
o Số tiền còn phải trả
o Ghi chú
11
2.2.2 Yêu cầu chức năng quản lý hợp đồng bán
- , bao gồm cả:
Thông tin chung về hợp đồng
Thông tin về tiến độ thực hiện hợp đồng
Thông tin về tiến độ thanh toán
- Các thông tin quản lý chung về hợp đồng:
Theo tờ trình
Mã hợp đồng
Số hiệu hợp đồng
Loại hợp đồng
Ngày ký hợp đồng
Thông tin về đơn vị thực hiện:
Đơn vị thực hiện
Người phụ trách chung (tên, email, điện thoại)
Người phụ trách trực tiếp (tên, email, điện thoại)
Thông tin về Khách hàng
Tên khách hàng
Người phụ trách (tên, email, điện thoại)
Giá trị hợp đồng
Kế hoạch thực hiện (bao gồm nhiều giai đoạn và hiển thị chi tiết kết quả của
từng giai đoạn)
Giai đoạn
Kết quả chi tiết
Tập tin đính kèm
Ghi chú
- Các thông tin về tiến độ thực hiện hợp đồng:
Biên bản nghiệm thu
o Ngày nghiệm thu
o Khối lượng nghiệm thu
12
o Giá trị nghiệm thu (Giá trị này được cộng dồn (luỹ kế) Giá trị của
trường. Giá trị thực hiện trong báo cáo)
Hóa đơn
o Ngày xuất
o Giá trị (Giá trị này được cộng dồn Giá trị xuất hóa đơn trong báo cáo)
o Số lượng
Biên bản quyết toán và thanh lý
o Ngày xuất
o Giá trị
o Khối lượng
Bảo lãnh thực hiện hợp đồng
o Giá trị bảo lãnh
o Thời hạn bảo lãnh: Từ ngày ….đến ngày….
o Giá trị ký quỹ
o Ngân hàng
o Tài khoản ký quỹ
Bảo lãnh bảo hành
o Giá trị bảo hành
o Thời hạn bảo hành: Từ ngày ….đến ngày….
o Giá trị ký quỹ
o Ngân hàng
o Tài khoản ký quỹ
- Các thông tin về tiến độ thanh toán:
Tình hình thanh toán: có hai kiểu thanh toán
o Thanh toán tạm ứng (Ngày thanh toán, Nợ tạm ứng, Giá trị thanh toán)
o Thanh toán theo tiến độ (Ngày thanh toán, Nợ thanh toán theo tiến độ, Giá
trị thanh toán, Cho biên bản nghiệm thu nào)
13
Chương 3: Kiến trúc hệ thống phần mềm nguồn mở ERP
Adempiere
Là một công ty chuyên về công nghệ, Viettel Technology đã thấy rõ được tầm quan
trọng của việc ứng dụng ERP trong doanh nghiệp, giải pháp ERP phù hợp được công ty
lựa chọn là hệ nguồn mở Adempiere.
3.1 Tổng quan về adempiere
ADempiere là một phần mềm mã nguồn mở, được phát triển trên nền nguồn mở
khác Compiere. Kiến trúc của hệ thống ADempiere dựa trên nền tảng Compiere
Application Dictionary hay AD Engine, nền tảng này phục vụ mô hình ba lớp Model-
View-Logic.
Mô hình tổng quan về hệ thống Adempiere được thể hiện như hình 2.
Hình 2. Mô hình kiến trúc hệ thống Adempiere [8]
14
Model Layer
Tại lớp Model, AD Engine quản lý tất cả các vấn đề liên quan đến các bảng, các
trường (như việc tạo mới, cập nhật, xóa) trong Database, các kiểu dữ liệu cũng như các
ràng buộc, xác thực của các trường này. Nhiệm vụ của AD Engine là chuẩn bị dữ liệu cho
lớp View để hiển thị ra màn hình chương trình.
Tất cả các bảng và các trường được xây dựng thông qua cửa sổ AD Table &
Column. Trong Adempiere, một trường có thể được tự động cập nhật thông tin từ các
trường khác thông qua các Callout (việc xây dựng Callout cho các trường được thực hiện
bằng cách mở rộng từ lớp CalloutEngine.java).
View layer
Lớp View có chức năng chủ yếu là hiển thị các trường thông tin do lớp Model cung
cấp ra màn hình chương trình. Bên cạnh đó, lớp view cũng cung cấp sẵn những chức năng
cơ bản để người dùng thao tác với dữ liệu (thêm, sửa, xóa) hay hỗ trợ việc tìm kiếm các
bản ghi.
Logic layer
Lớp Logic thực hiện các tác vụ có tính logic cho dữ liệu, các tác vụ mang tính
nghiệp vụ, các tác vụ liên quan đến tài chính...
3.2 Kiến trúc cơ bản của một ứng dụng trên Adempiere
Theo báo cáo của Phạm Anh Tuấn [7] kiến trúc cơ bản của một ứng dụng trên
Adempiere gồm các thành phần:
- Lớp PO
- Docaction
- Window
- Proccess
- Workflow
3.2.1 Lớp PO
Lớp PO là khái niệm thuộc tầng Model chứa trong gói
Base/src/org/compiere/model/PO.java
15
Là lớp quan trọng trong hệ thống, được ánh xạ vào tất cả các bảng dữ liệu trong cơ
sở dữ liệu dựa vào hai lớp con M, X và Interface I thông qua bảng AD_Table.
Lớp PO: định nghĩa hầu hết các thủ tục cần thiết để thao tác với một bảng dữ
liệu trong cơ sở dữ liệu như save(), delete()...
Interface I: Khai báo các biến để thao tác với tên cột, các hàm get, set để lấy
hoặc thiết đặt giá trị cho một cột. Interface I cần được implement bởi lớp X.
Lớp X: là lớp extends từ lớp PO và implement interface I. Trong lớp X sẽ cài
đặt cho các phương thức được khai báo trong interface I (interface I và lớp X có
thể được sinh ra bằng một công cụ có sẵn của hệ thống Adempiere. Không cần
phải viết hai lớp này).
Lớp M: là lớp extends lớp X. Khi các xử lý của lớp X là chưa đáp ứng được các
thao tác yêu cầu cần thiết, ta cần phải tạo thêm lớp M với quy tắc đặt tên nhất
định. (Quy tắc đặt tên lớp M: Với các bảng có tiền tố là một hoặc hai chữ cái thì
bỏ các chữ cái tiền tố này và ký tự “_” , thay vào đó là chữ M.
Ví dụ: bảng AD_Table --> MTable. Với bảng có tiền tố là ba chữ cái trở lên thi
bỏ các ký tự “_” và thêm M vào phía trước. VD: VTT_Abc--> MVTTAbc). Khi
tạo lớp M, có bốn hàm thông dụng nhất mà thường hay được override (từ lớp PO)
là các hàm:
o BeforeSave(). Hàm này sẽ được gọi trước khi thực hiện hàm ghi dữ liệu
Save(). Sử dụng BeforeSave() cho mục đích thay đổi, kiểm tra thông tin trước
khi ghi vào cơ sở dữ liệu. Ví dụ: Trong CSDL có ba trường là “Đơn giá”,
“Tổng tiền”, “Số lượng”, nhưng trong cửa sổ chỉ hiển thị hai trường là “Đơn
giá”, “Số lượng”, thì trước khi Save() viết BeforeSave() để tính giá trị cho
“Tổng tiền”.
o AfterSave(). Hàm này thực thi sau khi đã thực hiện Save(). Sử dụng
AfterSave() nếu dữ liệu khi ghi vào cơ sở dữ liệu tác động đến các thành phần
khác của hệ thống. Ví dụ như khi lưu dữ liệu ở các dòng chi tiết của một hóa
đơn, thì cần cập nhật tổng tiền ở phần tổng hợp.
o BeforeDelete(). Tương tự BeforeSave(), BeforeDelete() thực thi trước khi
thực sự xóa dữ liệu trong cơ sở dữ liệu. Có thể dùng hàm này để kiểm tra các
ràng buộc, xóa trước các trường trong các bảng khác có ràng buộc cha, con với
bảng đang thực hiện xóa...
16
o AfterDelete(). Hàm này thực thi sau khi xóa dữ liệu trên cơ sở dữ liệu.
*Chú ý:
- Việc ánh xạ các lớp M, X, PO vào các bảng trong cơ sở dữ liệu được thực hiện
trong phương thức getClass của lớp MTable.
- Khi một bảng trong DataBase không được tạo lớp X, M và Interface I tương ứng
thì hệ thống sẽ tự động gọi một lớp default để đảm bảo việc thực hiện các thao tác tối
thiểu như thêm, sửa, xóa... Lớp này là GenericPO.java (Chúng ta không cần phải quan
tâm đến lớp này).
Ví dụ: Với bảng M_InOut trong DataBase
Bảng này sẽ được ánh xạ với các lớp và Interface sau để thao tác trong hệ thống
(Các lớp này đều có trong gói base/org/compiere/model):
Interface : I_M_InOut.
public interface I_M_InOut
Class: X_M_InOut
public class X_M_InOut extends PO implements I_M_InOut
Class: MInOut extends PO
public class MInOut extends X_M_InOut implements DocAction
Trong lớp MInOut override hai hàm: BeforeSave() và AfterSave() để làm các thao
tác xử lý trước và sau khi ghi dữ liệu vào cơ sở dữ liệu.
3.2.2 DocAction
DocAction là khái niệm thuộc tầng logic chứa trong gói
base/org/compiere/proccess/DocAction.java
DocAction là một interface, trong này định nghĩa các trạng thái và hành động cho
một document như phụ lục 01.
Khi thao tác với lớp PO, thì là đề cập đến các vấn đề liên quan đến tính toán dữ liệu,
lưu trữ... Nhưng khi làm với DocAction là liên quan đến quy trình. Như các giấy tờ sẽ
17
được lưu chuyển từ phòng ban này sang phòng ban khác như thế nào, trạng thái của một
document là như thế nào...
Để thao tác với DocAction thì phải implement nó.
Ví dụ: Với lớp MInOut:
public class MInOut extends X_M_InOut implements DocAction
Đồng thời bảng trong CSDL cũng phải có các trường sau:
- DocAction
- DocStatus
- Proccessed
- Proccessing.
- C_Doctype_ID
- Posted (Sẽ cần trường này nếu liên quan đến hoạch toán).
DocAction cần được kích hoạt bằng nút nhấn. Sau khi kích hoạt sẽ chạy hàm
processIt() trong lớp M tương ứng. (Với bảng M_InOut thì là hàm trong lớp MInOut).
Hai hàm được implement đáng chú ý nhất là: prepareIt() và completeIt():
- Hàm prepareIt() thực hiện tất cả các yêu cầu, các tác vụ cần thiết trước khi
document được thực hiện quá trình complete. Hàm prepareIt() có thể được gọi nhiều lần
cho đến khi hàm completeIt() thực thi.
- Hàm completeIt() thực hiện quá trình “complete document”. Sau khi thực hiện,
trạng thái của document sẽ chuyển thành “complete” và hành động tiếp theo sẽ là “close”.
- Ngoài ra, hàm reActivateIT() là hàm có chức năng làm ngược lại những gì hai hàm
completeIt() và prepareIt() đã làm.
Một vấn đề quan trọng khác trong quy trình là liên quan đến hoạch toán. Khi người
dùng post dữ liệu để hoạch toán. Gói base/src/org/compiere/acct chứa các lớp sẽ xử lý về
vấn đề hoạch toán.
3.2.3 Window
Window là khái niệm thuộc tầng View.
18
Window là khái niệm phổ biến nhất trong Adempiere. Window là nơi người dùng
thao tác với dữ liệu, đồng thời cũng là nơi người phát triển hệ thống có thể làm việc để
trực tiếp mở rộng hệ thống. Tất cả các window đểu có một giao diện đồng nhất, và giao
diện này được tạo ra trong quá trình chạy ứng dụng (Runtime). Một window sẽ có giao
diện tương tự như sau:
Hình 3. “Window, Tab & Field” của Adempiere
Cấu trúc một window:
- Phần trên cùng là các menu.
- Tiếp theo là các button thực hiện các thao tác thông dụng: New, delete, search, các
nút dịch chuyển qua các record, close...
- Phần bên trái là các tab, một window có thể có nhiều tab. Mỗi tab tương ứng với
một bảng trong cơ sở dữ liệu.
19
- Phía bên phải là chi tiết trong một tab. Gồm các bản ghi (mổi bản ghi tương ứng
một dòng trong cơ sở dữ liệu).
- Mỗi bản ghi gồm nhiều field.
- Mỗi field là một cột dữ liệu trong cơ sở dữ liệu. Tuy nhiên trong cơ sở dữ liệu, một
bản ghi có thể có nhiều cột, nhưng trên window có thể chỉ được cấu hình để hiển thị một
số cột.
- Có thể chuyển từ việc hiển thị nhiều dòng (grid) thành hiển thị chi tiết từng bản ghi
bằng cách ấn nút Grid Toggle.
Các bước tạo mới một window:
- Dùng window Table&Column để tạo mới một bảng trong cơ sở dữ liệu.
Hình 4. “Table & Column” của Adempiere
- Chú ý: Tất cả các bảng (table) được tạo trong cơ sở dữ liệu của hệ thống
Adempiere đều phải có các cột được định nghĩa như phụ lục 02 (Chúng ta có thể click
20
nút “Copy column from Table” rồi chọn table khác để lấy toàn bộ các cột trong table đó.
VD table: Temp_temp).
- Sau khi tạo mới bảng, sử dụng window “Window, Tab & Field” để tạo mới
window.
- Trong tab “Tab”, tạo mới Tab và trỏ Tab này vào Table mới tạo.
- Sau đó chọn “Create Field” để tạo các Field từ bảng trong cơ sở dữ liệu và chọn
các Field sẽ được hiển thị trên màn hình.
- Chú ý: Một bảng có thể có nhiều tab. Một tab tương ứng với một bảng trong cơ sở
dữ liệu.
- Sau khi tạo Window, sử dụng window “Menu” để tạo menu trỏ tới window mới
tạo.
Hình 5. Tạo Menu của Adempiere
Các chú ý khi tạo window:
21
- Khi tạo mới Table, tạo trường có thuộc tính “Mandatory” là trường bắt buộc phải
nhập
- Trường có kiểu Table, Table Direct, Search là các trường sẽ lấy dữ liệu từ các bảng
khác.
- Trường có kiểu là ID (identification) thì bắt buộc tên là tên_bảng +”_ID”.
- Khi muốn tạo hai tab có quan hệ cha-con thì hai tab đó phải có mức (level) là i và
i+1. Table trong tap i+1 phải có cột ID của table tap level i. Trong tab i+1 phải khai báo
“link column” là tên của cột ID của table trong tab i.
3.2.4 Process
Process là khái niệm thuộc tầng View.
Process được khai báo trong window: Report & Process.
Process là một lớp java tuân theo một chuẩn nhất định, process được thực thi khi
một sự kiện sảy ra trong bản thân chương trình của hệ thống Adempiere (như một nút
được nhấn).
Một process luôn phải có hai phương thức là:
- prepare(): làm các thao tác để chuẩn bị cho việc thực thi process.
- doIt(): đoạn code thực thi chức năng của process.
Thông thường một process được gán với sự kiện một nút được nhấn.
3.2.5 WorkFlow
WorkFlow là khái niệm thuộc tầng Logic.
WorkFlow là một quy trình nghiệp vụ. Khi một lớp implement DocAction thì tức là
đã phải dựa theo một WorkFlow.
Có ba loại Workflow trong Adempiere là:
- General workflow: Cung cấp hướng dẫn từng bước để hoàn thành một công việc.
- Document process workflow: Bắt đầu khi processing bất kỳ document nào.
- Document value workflow.
3.3 Đánh giá về hệ thống Adempiere
Hiện nay, bên cạnh Adempiere chúng ta cũng thấy có rất nhiều giải pháp phần mềm
ERP khác như:
22
+ Nguồn mở: Openbravo, Compiere, Opentabs…
+ Nguồn đóng: SAP, Oracle, Microsoft Dynamics…
Tuy nhiên Adempiere được Viettel lựa chọn phát triển vì được cộng đồng đánh giá
[9] với nhiều ưu điểm sau:
- Adempiere là một phần mềm nguồn mở và hoàn toàn miễn phí.
- Hệ thống Adempiere phù hợp với những doanh nghiệp vừa và nhỏ.
- Adempiere hỗ trợ sử dụng đa ngôn ngữ (trong đó có tiếng Việt), nhiều loại tiền tệ
và nhiều kiểu đối tượng là doanh nghiệp. Vì vậy cho phép doanh nghiệp sử dụng
Adempiere có thể cộng tác được với nhiều công ty nằm trong cùng một chuỗi cung ứng
hoặc trong cùng một tập đoàn quốc gia hoặc xuyên quốc gia.
- Hệ thống Adempiere ổn định, hiệu năng cao, linh hoạt, dễ sử dụng, dễ dàng trong
việc bảo trì vả mở rộng các ứng dụng của sản phẩm.
- Adempiere có giao diện người dùng thân thiện, trực quan, được tổ chức tốt.
- Adempiere là sản phẩm được xây dựng bởi một cộng đồng phát triển nên
Adempiere thường xuyên được cải tiến và tích hợp thêm những tính năng mới từ các
thành viên tham gia phát triển trên toàn cầu.
- Adempiere được hỗ trợ bởi nhiều công cụ để kiểm thử, nâng cấp, chuyển đổi và
sửa lỗi hay cải tiến mã nguồn.
- Adempiere được ứng dụng các công cụ nguồn mở hiện đại trong việc phát triển.
Bên cạnh những ưu điểm thì hệ thống cũng có những nhược điểm như:
- Adempiere là một hệ thống có cấu trúc khá phức tạp nên việc cài đặt là tương đối
khó.
- Hiệu quả của hệ thống sẽ bị ảnh hưởng khi ta thêm chức năng mới vào cấu trúc
hiện tại.
23
Chương 4: Phân tích và triển khai phân hệ quản lý hợp đồng
trên Adempiere ở Viettel Technology
4.1 Phân tích và triển khai bài toán quản lý hợp đồng mua trên Adempiere
4.1.1 Quy trình xử lý
4.1.1.1 Quy trình xử lý
Quy trình xử lý bài toán quản lý hợp đồng mua được mô tả như dưới đây (Tài liệu
đặc tả yêu cầu người dùng dự án ERP-VTT [4]):
Hình 6. Mô tả quy trình quản lý hợp đồng mua [4]
4.1.1.2 Mô tả các bước trong quy trình
Theo tài liệu đặc tả yêu cầu người dùng dự án ERP-VTT [4] quy trình xử lý của
bài toán quản lý hợp đồng mua qua các bước:
- Bước 1: Đơn vị, phòng ban có nhu cầu lập hợp đồng.
- Bước 2: Phòng Đầu tư kiểm tra hợp đồng. Nếu đồng ý thì chuyển qua phòng Tài
chính, nếu không đề nghị sửa.
24
- Bước 3: Phòng Tài chính kiểm tra hợp đồng. Nếu đồng ý thì chuyển lên Ban giám
đốc, nếu không đề nghị sửa.
- 4: Sau khi được Ban giám đốc phê duyệt, phòng Đầu tư cập nhật tiến độ
thực hiện hợp đồng, đơn vị phòng ban và phòng Đầu tư thực hiện việc nhập kho.
- 5: Phòng Tài chính theo dõi và cập nhật tiến độ thanh toán của hợp đồng.
4.1.2 Mô tả Use Case mức cao
Mô hình Use Case mức cao của quy trình quản lý hợp đồng mua được mô trong tài
liệu đặc tả yêu cầu người dùng của dự án ERP-VTT [4] như hình 7.
Hình 7. Mô hình Use Case mức cao-Quản lý hợp đồng mua [4]
Mô hình Use Case của Quản lý hợp đồng mua có ba tác nhân (actor) là: Đơn vị sử
dụng, Phòng Đầu tư, Phòng Tài chính.
- Khi một Đơn vị sử dụng có nhu cầu, hệ thống sẽ lập một hợp đồng mua theo các
yêu cầu mà đơn vị đưa ra.
25
- Khi phòng Đầu tư muốn cập nhật thông tin của hợp đồng mua, hệ thống sẽ phải
hiển thị các thông tin về tiến độ thực hiện của hợp đồng, thông tin của việc nhập kho và
cho phép phòng Đầu tư có thể thực hiện việc cập nhật.
- Khi phòng Tài chính muốn cập nhật thông tin của hợp đồng mua, hệ thống sẽ phải
hiển thị các thông tin về tiến độ thanh toán của hợp đồng và cho phép phòng Tài chính có
thể thực hiện việc cập nhật.
- Trong quá trình thực hiện hợp đồng, Đơn vị sử dụng cũng thường xuyên thực hiện
việc nhập kho, hệ thống phải theo dõi và cập nhật được thông tin này để cung cấp cho
phòng Đầu tư và Đơn vị sử dụng khi cần.
4.1.3 Biểu đồ phân rã chức năng
Hình 8. Biểu đồ phân rã chức năng-Quản lý hợp đồng mua
Phân hệ quản lý hợp đồng mua gồm có ba chức năng chính là:
- Quản lý thông tin chung về hợp đồng.
- Quản lý thông tin về tiến độ thực hiện hợp đồng.
- Quản lý thông tin về tiến độ thanh toán.
Mỗi chức năng sẽ được gán cho một role riêng:
- Chức năng quản lý thông tin chung về hợp đồng được gán cho Đơn vị sử dụng.
- Chức năng quản lý thông tin về tiến độ thực hiện hợp đồng được gán cho phòng
Đầu tư.
- Chức năng quản lý thông tin về tiến độ thanh toán được gán cho phòng Tài chính.
Quản lý hợp đồng mua
Thông tin chung
về hợp đồng
Thông tin về tiến độ
thực hiện hợp đồng
Thông tin về tiến độ
thanh toán
26
4.1.4 Mô hình ER
Hình 9. Mô hình ER-Quản lý hợp đồng mua
Các thực thể cùng các thuộc tính trong mô hình:
Ban
giám
đốc
Hợp
đồng
Phòng
tài
chính
Phòng
đầu tư
Đơn
vị sử
dụng
Kho
Kiểm
tra
Phê
duyệt
Y/C
nhập
kho
Y/C
nhập
kho
Cập nhật
thực hiện
Khởi
tạo
Cập nhật
thanh toán
Kiểm
tra
(1,1)
(1,1)
(1,1)
(1,1)
(1,n)
(1,1)
(1,1)
(1,1)
(1,1)
(1,n)
(1,1)
(1,n)
(1,n)
(1,1)
(1,1)
(1,n)
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID EMPLOYEE_ID
CONTRACT_ID BPARTNER_ID DEPARTMENT_ID
DATE
CREATBY
TOTALAMOUNT
CURRENCY
27
- Hợp đồng: CONTRACT_ID, DEPARTMENT_ID, BPARTNER_ID, DATE,
CREATBY, TOTALAMOUNT, CURRENCY.
- Đơn vị sử dụng: DEPARTMENT_ID, EMPLOYEE_ID.
- Phòng đầu tư: DEPARTMENT_ID, EMPLOYEE_ID.
- Phòng tài chính: DEPARTMENT_ID, EMPLOYEE_ID.
- Ban giám đốc: DEPARTMENT_ID, EMPLOYEE_ID.
- Kho: DEPARTMENT_ID, EMPLOYEE_ID.
4.1.5 Triển khai trên Adempiere
Việc triển khai module quản lý hợp đồng mua được thực hiện dựa trên các thành
phần chính của Adempiere là window, workflow, process và các mô tả chức năng của bài
toán.
4.1.5.1 Xây dựng window cho quản lý hợp đồng mua
Tạo bảng VTT_BuyingContract trong cơ sở dữ liệu với các trường thông tin như
mô tả ở phần yêu cầu chức năng.
Sử dụng chức năng Table & Column để tạo bảng VTT_BuyingContract trong
Adempiere:
28
Hình 10. Tạo bảng VTT_BuyingContract
Sau khi điền các thông tin cần thiết ta nhấn nút Create Column From Table để
lấy các trường có trong bảng VTT_BuyingContract trong cơ sở dữ liệu. Tiếp đó, ta dùng
tab Column để lấy các trường muốn hiển thị.
Sử dụng chức năng Window, Tab & Field để tạo mới cửa sổ VTT Buying
Contract:
29
Hình 11. Tạo cửa sổ “VTT Buying Contract”
Sử dụng tab Tab để tạo mới các tab:
30
Hình 12. Tạo tab VTT Buying Contract
Tab này sẽ hiển thị các thông tin chung về hợp đồng
31
Hình 13. Tạo tab Payment Progress
Tab này sẽ hiển thị các thông tin về tiến độ thanh toán
32
Hình 14. Tạo tab Supplying Product
Tab này sẽ hiển thị các thông tin về sản phẩm.
Sau khi tạo xong window VTT Buying Contract ta chạy file GenerateModel.java
trong gói org.adempiere.util để tạo lớp I, lớp X cho window vừa mới tạo.
4.1.5.2 Gắn vào menu
Ta sử dụng chức năng Menu để gắn menu VTT Buying Contract vào hệ thống
33
Hình 15. Tạo Menu “VTT Buying Contract”
4.1.5.3 Tạo workflow cho chức năng quản lý hợp đồng mua
Đăng nhập vào Adempiere với tài khoản là SuperUser và Role là VTT admin.
Tạo mới các role để xử lý workflow bằng việc sử dụng chức năng Role để tạo mới
các role sau: VTT Investment Dept Staff, VTT Financial Dept Staff, VTT Investment
Dept Chief, VTT Financial Dept Chief .
34
Hình 16. Tạo mới các role xử lý workflow
Sử dụng chức năng Workflow để tạo mới workflow cho chức năng quản lý hợp
đồng mua
35
Hình 17. Tạo workflow “Buying Contract”
Tạo mới các node cho workflow:
+ Node Start
36
Hình 18. Tạo node Start workflow “VTT Buying Contract”
Node Start sẽ khởi đầu cho một workflow
+ Node Prepare
37
Hình 19. Tạo node Prepare workflow “VTT Buying Contract”
Node Prepare sẽ chuẩn bị thiết lập các thông tin cho document.
+ Node Approved (node này được gán cho role là trưởng phòng đầu tư- Investment
Dept Chief)
38
Hình 20. Tạo node Approved workflow “VTT Buying Contract”
+ Node Doc Complete
39
Hình 21. Tạo node Doc Complete workflow “VTT Buying Contract”
Node Doc Complete đánh dấu việc một document đã được điền đầy đủ thông tin.
+ Node Doc Auto
40
Hình 22. Tạo node Doc Auto workflow “VTT Buying Contract”
+ Node Send Request
41
Hình 23. Tạo node Send Request workflow “VTT Buying Contract”
Node Send Request sẽ là node gửi các yêu cầu về việc cập nhật tiến độ thực hiện
hay tiến độ thanh toán.
+ Node Update Payment Progress (node này được gán cho role phòng tài chính-
Financial Dept Staff).
42
Hình 24. Tạo node Update Payment Progress
Node này có chức năng cập nhật thông tin về tiến độ thanh toán.
+ Node Update Performance Progress (node này được gán cho role Phòng đầu tư-
Investment Dept Staff).
43
Hình 25. Tạo node Update Performance Progress
workflow “VTT Buying Contract”
Node này có chức năng cập nhật tiến độ thực hiện.
Chúng ta có thể xem và chỉnh sửa workflow thông qua chức năng Workflow Editor
44
Hình 26. Hiển thị workflow “VTT Buying Contract”
4.1.5.4 Gắn workflow với Process
- Sử dụng chức năng quản lý Report&Process để tạo ra một process cho workflow
Buying Contract và gắn workflow vào.
o Name: Buying Contract Process
o Data Access level: chọn all.
o Report type: Standard.
o Workflow: Chọn Buying Contract
o Các thông số khác đặt mặc định.
45
Hình 27. Tạo Process cho workflow “VTT Buying Contract”
- Sử dụng chức năng Quản lý Table, Column and Field để gắn process vào trường
DocAction
o Reference: Button.
o Process: Chọn Buying Contract Process
o Reference Key: _DocumentAction
o Default Logic: CO
o Updateable: Tích chọn
o Các thuộc tính khác đặt giá trị mặc định
46
Hình 28. Gắn process “Buying Contract Process” vào trường Doc Action
4.2 Phân tích và triển khai bài toán quản lý hợp đồng bán trên Adempiere
4.2.1 Mô tả quy trình xử lý
4.2.1.1 Quy trình xử lý
Quy trình xử lý bài toán quản lý hợp đồng bán được mô tả như dưới đây (Tài liệu
đặc tả yêu cầu người dùng dự án ERP-VTT [4]):
47
Hình 29. Mô tả quy trình quản lý hợp đồng bán [4]
4.2.1.2 Mô tả các bước trong quy trình
Theo tài liệu đặc tả yêu cầu người dùng dự án ERP-VTT [4] quy trình xử lý của bài
toán quản lý hợp đồng bán qua các bước:
- Bước 1: Đơn vị, phòng ban có nhu cầu lập hợp đồng.
- Bước 2: Phòng Đầu tư kiểm tra hợp đồng. Nếu đồng ý thì chuyển qua phòng Tài
chính, nếu không đề nghị sửa.
- Bước 3: Phòng Tài chính kiểm tra hợp đồng. Nếu đồng ý thì chuyển lên Ban giám
đốc, nếu không đề nghị sửa.
- 4: Sau khi được Ban giám đốc phê duyệt, phòng Đầu tư cập nhật tiến độ
thực hiện hợp đồng, đơn vị phòng ban và Phòng đầu tư thực hiện việc xuất kho.
- 5: Phòng tài chính theo dõi và cập nhật tiến độ thanh toán của hợp đồng.
4.2.2 Mô tả Use Case mức cao
Mô hình Use Case mức cao của quy trình quản lý hợp đồng bán được mô trong tài
liệu đặc tả yêu cầu người dùng của dự án ERP-VTT [4] như hình 30.
48
Hình 30. Mô hình Use Case mức cao-Quản lý hợp đồng bán [4]
Mô hình Use Case của Quản lý hợp đồng bán có ba tác nhân (actor) là: Đơn vị sử
dụng, Phòng Đầu tư, Phòng Tài chính.
- Khi một Đơn vị sử dụng có nhu cầu, hệ thống sẽ lập một hợp đồng bán theo các
yêu cầu mà Đơn vị sử dụng đưa ra.
- Khi phòng Đầu tư muốn cập nhật thông tin của hợp đồng bán, hệ thống sẽ phải
hiển thị các thông tin về tiến độ thực hiện của hợp đồng, thông tin của việc xuất kho và
cho phép phòng Đầu tư có thể thực hiện việc cập nhật.
- Khi phòng Tài chính muốn cập nhật thông tin của hợp đồng bán, hệ thống sẽ phải
hiển thị các thông tin về tiến độ thanh toán của hợp đồng và cho phép phòng Tài chính có
thể thực hiện việc cập nhật.
- Trong quá trình thực hiện hợp đồng, Đơn vị sử dụng cũng thường xuyên thực hiện
việc xuất kho, hệ thống phải theo dõi và cập nhật được thông tin này để cung cấp cho
phòng Đầu tư và Đơn vị sử dụng khi cần.
49
4.2.3 Biểu đồ phân rã chức năng
Hình 31. Biểu đồ phân rã chức năng-Quản lý hợp đồng bán
Phân hệ quản lý hợp đồng bán gồm có ba chức năng chính là:
- Quản lý thông tin chung về hợp đồng
- Quản lý thông tin về tiến độ thực hiện hợp đồng
- Quản lý thông tin về tiến độ thanh toán
Mỗi chức năng sẽ được gán cho một role riêng:
- Chức năng quản lý thông tin chung về hợp đồng được gán cho Đơn vị sử dụng.
- Chức năng quản lý thông tin về tiến độ thực hiện hợp đồng được gán cho phòng
Đầu tư.
- Chức năng quản lý thông tin về tiến độ thanh toán được gán cho phòng Tài chính.
Quản lý hợp đồng bán
Thông tin chung
về hợp đồng
Thông tin về tiến độ
thực hiện hợp đồng
Thông tin về tiến độ
thanh toán
50
4.1.4 Mô hình ER
Hình 32. Mô hình ER-Quản lý hợp đồng bán
Các thực thể cùng các thuộc tính trong mô hình:
- Hợp đồng: CONTRACT_ID, DEPARTMENT_ID, BPARTNER_ID, DATE,
CREATBY, TOTALAMOUNT, CURRENCY.
- Đơn vị sử dụng: DEPARTMENT_ID, EMPLOYEE_ID.
Ban
giám
đốc
Hợp
đồng
Phòng
tài
chính
Phòng
đầu tư
Đơn
vị sử
dụng
Kho
Kiểm
tra
Phê
duyệt
Y/C
xuất
Y/C
xuất
Cập nhật
thực hiện
Khởi
tạo
Cập nhật
thanh toán
Kiểm
tra
(1,1)
(1,1)
(1,1)
(1,1)
(1,n)
(1,1)
(1,1)
(1,1)
(1,1)
(1,n)
(1,1)
(1,n)
(1,n)
(1,1)
(1,1)
(1,n)
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID
EMPLOYEE_ID
DEPARTMENT_ID EMPLOYEE_ID
CONTRACT_ID BPARTNER_ID DEPARTMENT_ID
DATE
CREATBY
TOTALAMOUNT
CURRENCY
51
- Phòng đầu tư: DEPARTMENT_ID, EMPLOYEE_ID.
- Phòng tài chính: DEPARTMENT_ID, EMPLOYEE_ID.
- Ban giám đốc: DEPARTMENT_ID, EMPLOYEE_ID.
- Kho: DEPARTMENT_ID, EMPLOYEE_ID.
4.2.5 Triển khai trên Adempiere
Việc triển khai chức năng quản lý hợp đồng bán hoàn toàn tương tự như phần triển
khai với chức năng quản lý hợp đồng mua với việc xuất phát từ bảng
VTT_SellingContracct trong cơ sở dữ liệu.
4.3 Đánh giá hiệu quả làm việc của hệ thống
Qua quá trình chạy thử, kết quả là các chức năng như lập hợp đồng, cập nhật tiến độ
thực hiện, cập nhật tiến độ thanh toán đã thỏa mãn được những yêu cầu ban đầu đề ra.
Trong thực nghiệm, hệ thống đã có thể hỗ trợ hàng chục người sử dụng cùng một
lúc. Tuy nhiên, do cơ sở dữ liệu là tương đối lớn (vì phải xây dựng cơ sở dữ liệu chung
cho cả doanh nghiệp) cho nên việc kết nối cơ sở dữ liệu là hơi mất thời gian.
Đồng thời trong quá trình thử nghiệm đã cho thấy dữ liệu luôn đạt được sự đồng
nhất mặc dù đã có nhiều người dùng thuộc nhiều phòng ban cùng tác động lên dữ liệu.
Với tính năng workflow, các hoạt động mua/bán của doanh nghiệp đều đã được thực
hiện theo đúng các quy trình nghiệp vụ với thời gian thực hiện được rút ngắn, các bước
thực hiện đều được gán với vai trò của mỗi nhân viên, phòng ban nhất định nên việc kiểm
soát trách nhiệm là đơn giản.
52
Kết Luận
Nhu cầu về việc triển khai ERP trong các doanh nghiệp ngày càng cần thiết, trong
đó việc xây dựng module Quản lý hợp đồng là một phần quan trọng trong tổng thể hệ
thống ERP chịu ảnh hưởng riêng bởi đặc trưng sản xuất kinh doanh của từng doanh
nghiệp.
Khóa luận này đã giúp chúng ta tiếp cận gần hơn với một hệ thống ERP, thực hiện
việc xây dựng và triển khai phân hệ Quản lý hợp đồng trong thực tế.
Khóa luận đã đạt được những kết quả sau:
- Tìm hiểu được vai trò, ý nghĩa của ERP trong doanh nghiệp.
- Tìm hiểu được một giải pháp ERP trong thực tế là Adempiere.
- Xây đựng và triển khai được ứng dụng về quản lý hợp đồng trên hệ nguồn mở
Adempiere trong thực tế.
Do thời gian và kiến thức hạn chế của tác giả nên khóa luận không khỏi có những
thiếu sót. Những thiếu sót này cần được bổ sung và tiếp tục hoàn thiện.
53
Phụ lục 01: Các trạng thái và hành động cho một document.
/* Complete = CO */
public static final String ACTION_Complete = "CO";
/* Wait Complete = WC */
public static final String ACTION_WaitComplete = "WC";
/* Approve = AP */
public static final String ACTION_Approve = "AP";
/* Reject = RJ */
public static final String ACTION_Reject = "RJ";
/* Post = PO */
public static final String ACTION_Post = "PO";
/* Void = VO */
public static final String ACTION_Void = "VO";
/* Close = CL */
public static final String ACTION_Close = "CL";
/* Reverse - Correct = RC */
public static final String ACTION_Reverse_Correct = "RC";
/* Reverse - Accrual = RA */
public static final String ACTION_Reverse_Accrual = "RA";
/* ReActivate = RE */
public static final String ACTION_ReActivate = "RE";
/* = -- */
public static final String ACTION_None = "--";
/* Prepare = PR */
public static final String ACTION_Prepare = "PR";
54
/* Unlock = XL */
public static final String ACTION_Unlock = "XL";
/* Invalidate = IN */
public static final String ACTION_Invalidate = "IN";
/* ReOpen = OP */
public static final String ACTION_ReOpen = "OP";
/* Drafted = DR */
public static final String STATUS_Drafted = "DR";
/* Completed = CO */
public static final String STATUS_Completed = "CO";
/* Approved = AP */
public static final String STATUS_Approved = "AP";
/* Invalid = IN */
public static final String STATUS_Invalid = "IN";
/* Not Approved = NA */
public static final String STATUS_NotApproved = "NA";
/* Voided = VO */
public static final String STATUS_Voided = "VO";
/* Reversed = RE */
public static final String STATUS_Reversed = "RE";
/* Closed = CL */
public static final String STATUS_Closed = "CL";
/* Unknown = ?? */
public static final String STATUS_Unknown = "??";
/* In Progress = IP */
55
public static final String STATUS_InProgress = "IP";
/* Waiting Payment = WP */
public static final String STATUS_WaitingPayment = "WP";
/* Waiting Confirmation = WC */
-public static final String STATUS_WaitingConfirmation = "WC";
Phụ lục 02: Định nghĩa các cột bắt buộc có trong một table của hệ thống Adempiere.
AD_CLIENT_ID NUMERIC(10)NOT NULL,
AD_ORG_ID NUMERIC(10) NOT NULL,
ISACTIVE CHAR(1)DEFAULT 'Y' NOT NULL,
CREATED DATE DEFAULT NOW() NOT NULL,
CREATEDBY NUMERIC(10)NOT NULL,
UPDATED DATE DEFAULT NOW()sNOT NULL,
UPDATEDBY NUMERIC(10)NOT NULL,…
- Chú ý: phải đặt tên cột ID của bảng là tên_bảng + “_ID”.
56
Tài liệu tham khảo
Tiếng Việt:
[1] ErpVietNam,Erp là gì,
[2] Fast, Giới thiệu về ERP,
thiu-v-erp-fast&catid=111%3Agiai-phap-erp&lang=vi&limitstart=1.
[3] Wiki, Hoạch định tài nguyên doanh nghiệp,
ạch_định_tài_nguyên_doanh_nghiệp.
[4] Lê Thị Thanh Nhàn, “Tài liệu đặc tả yêu cầu người dùng dự án ERP-VTT”, Viettel
Technologies, 2009, Chương 3, Tr.20-26.
[5] TS.Đỗ Việt Nga, ThS.Đinh Kim Dung, “Giáo trình Phân tích, thiết kế, xây dựng,
quản lý các hệ thống thông tin”, Viện Công nghệ thông tin, 2004, Chương 3, Tr.43-51.
[6] Trần Đình Quế, Nguyễn Mạnh Sơn, “Phân tích và thiết kế hệ thống thông tin”, Học
viện công nghệ bưu chính viễn thông, 2007, Chương 3, Tr.48-57.
[7] Phạm Anh Tuấn, “Báo cáo phân tích hệ thống Adempiere”, Viettel Technologies,
2009, Phần 3, Tr.22-32.
Tiếng Anh:
[8] Application Dictionary,
[9] Adempiere-erpcrm,
Các file đính kèm theo tài liệu này:
- LUẬN VĂN- ỨNG DỤNG ERP ADEMPIERE TRONG QUẢN LÝ HỢP ĐỒNG.pdf