Xây dựng phần mềm quản lý kho gỗ của chi nhánh công ty ván gỗ ép MDF Gia Lai

Phần mềm được viết bằng ngôn ngữ Visual Basic sẽ được đóng gói ra file *.exe để chạy. Phần mềm được đóng gói sẽ gồm 1 đĩa CD bao gồm code và các file để chạy chương trình. Công ty MDF Gia Lai sẽ cho người hướng dẫn nhõn viên phòng quản lý kho cài đặt phần mềm cũng như đào tạo người sử dụng. Sau khi cài đặt, phần mềm sẽ được bảo trì miễn phí cũng như sửa chữa phần mềm nếu có sự cố xảy ra cho công ty trong vũng 6 tháng tiếp theo.

doc79 trang | Chia sẻ: lylyngoc | Lượt xem: 2744 | Lượt tải: 2download
Bạn đang xem trước 20 trang tài liệu Xây dựng phần mềm quản lý kho gỗ của chi nhánh công ty ván gỗ ép MDF Gia Lai, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
MỤC LỤC LỜI NểI ĐẦU Công nghệ phần mềm là lĩnh vực nghiên cứu của tin học nhằm đề xuất các nguyên lý, phương pháp, công cụ, cách tiếp cận và phương tiện phục vụ cho việc thiết kế và cài đặt các sản phẩm phần mềm một cách kinh tế, vừa tin cậy, vừa làm việc hiệu quả trên máy tớnh. Sau một thời gian được tiếp thu những kiến thức quý bỏu trong môn Công nghệ phần mềm do thầy PGS.TS Hàn Viết Thuận giảng dạy, chúng em đã có cơ hội được thực hành để xõy dựng nên một phần mềm, qua đó cụ thể hoá những kiến thức đã học. Đề tài nhóm 3 - Tin học kinh tế 48 chúng em lựa chọn là “Xõy dựng phần mềm quản lý kho gỗ của chi nhánh công ty ván gỗ ép MDF Gia Lai”. Qua từng tuần, thực hiện từng quy trình trong công nghệ phần mềm, cùng với sự hướng dẫn nhiệt tình của thầy Thuận, sự đóng góp ý kiến của các bạn trong lớp, và sự miệt mài làm việc của nhóm 3, chúng em đã cho ra mắt phần mềm đáp ứng được yêu cầu cao của người sử dụng. Quóng thời gian làm việc cùng nhau của nhóm 3 không chỉ là cơ hội tốt để các thành viên học cách làm việc tập thể, cùng nhau giải quyết những vấn đề khó khăn, mà cũn là dịp để các bạn thật sự hiểu nhau hơn, chia sẻ những cảm xúc tươi mới và luôn vẹn nguyên trong tình bạn. Tất cả cùng nhau “đoàn kết sáng tạo và không ngừng vươn xa”. Chúng em xin chõn thành cảm ơn Phó giáo sư, tiến sĩ Hàn Viết Thuận, người đã trực tiếp giảng dạy và hướng dẫn chúng em thực hiện đề tài. Chúng em mong thầy luôn là điểm tựa vững chắc để chúng em có thể vững bước trên con đường mình đã chọn. Chỳng em cũng xin gửi lời cám ơn đến Chi nhánh công ty ván gỗ ép MDF Gia Lai đã tạo điều kiện tốt nhất cho chúng em thực hiện thành công đề tài này. Hà Nội, 11/2009 Nhóm sinh viên thực hiện Nhóm 3 - Tin học kinh tế 48 1.Tổng quan 1.1 Giới thiệu về chi nhánh công ty ván gỗ ép MDF Gia Lai TỔNG CÔNG TY LÂM NGHIỆP VIỆT NAM - VINAFOR Chi nhánh công ty ván gỗ ép MDF Gia Lai -Địa chỉ:32 – Đại Từ - Đại Kim – Hà Nội -Điện thoại: 04.35400826 -Fax : 04.6283690 -Email: vinafor_kt@fpt.vn -Website: www.vinafor.com.vn Đụi nét về công ty: Ván Sợi (MDF) là ván nhân tạo có đặc tính cơ lý cao, kích thước lớn, phù hợp với công nghệ sản xuất đồ mộc nội thất trong vùng khí hậu nhiệt đới. Nhà máy MDF Gia Lai của VINAFOR có công suất 54.000 m3 SP/năm sử dụng dây chuyền công nghệ hiện đại châu Âu và được quản lý theo hệ thống quản lý chất lượng ISO 9001-2000. Quy cách sản phẩm 1.830 mm x 2.440mm dầy từ 6-30mm. Sản phẩm ván MDF được sử dụng rộng rãi trong các lĩnh vực sản xuất đồ mộc, trang trí nội thất, xây dựng… 1.2 Giới thiệu nhóm 3 - Tin học kinh tế 48 Nhóm 3 - Tin học kinh tế 48 được thành lập 15 - 09 - 2009. Trong bối cảnh tin học hóa là một bước tiến bắt buộc đối với các doanh nghiệp. Nhóm 3 được thành lập với mục tiêu mang lại sự tin học hóa đến với doanh nghiệp.Được thành lập với các thành viên năng động có kiến thức chuyên môn sõu. Nhúm chúng tôi có quyết tâm biến kiến thức học được trên giảng đường thành các ứng dụng cho doanh nghiệp hiện đại. Danh sách các thành viên - Thiều Quang Huy - Nguyễn Tuấn Anh - Nguyễn Thị Thanh - Đinh Gia Cương - Đào Tuấn Cường - Nguyễn Thị Ngọc Bích - Vũ Danh Mạnh - Lò Đức Khoa - Hồ Hoàng Huệ 1.3 Bảng phân công công việc Nhiệm vụ Cán bộ phụ trách chính Thời gian thực hiện Xác định đề tài Cả nhóm 1 ngày Đi thực tế Cả nhóm 2 ngày Xây dựng hợp đồng Đào Tuấn Cường 4 ngày Xác định nhu cầu người sử dụng Nguyễn Thị Ngọc Bích Xây dựng HĐPM Đào Tuấn Cường Xác định yêu cầu Nguyễn Thị Thanh Hồ Hoàng Huệ 1 tuần Lập kế hoạch xác định yêu cầu Nguyễn Thị Thanh Xác định yêu cầu người sử dụng Nguyễn Thị Thanh Phân tích nghiệp vụ chuyên sâu Nguyễn Thị Thanh Mô hình hoạt động của hệ thống Hồ Hoàng Huệ Báo cáo quy trình 2 Nguyễn Thị Thanh Phân tích thiết kế Đào Tuấn Cường 2 tuần Lập kế hoạch thiết kế Vũ Danh Mạnh Thiết kế kiến trúc Đào Tuấn Cường Thiết kế dữ liệu Thiều Quang Huy Thiết kế thủ tục Nguyễn Tuấn Anh Thiết kế giao diện Đinh Gia Cương Lập trình Thiều Quang Huy 2 tuần Lập trình hệ thống Nguyễn Tuấn Anh Lập trình cập nhật danh mục Thiều Quang Huy Lập trình xử lý nghiệp vụ Thiều Quang Huy Nguyễn Tuấn Anh Lập trình tìm kiếm báo cáo Nguyễn Tuấn Anh Test Đinh Gia Cương Lò Đức Kho 1 tuần Lập kế hoạch Test Lò Đức Khoa Lập kịch bản Test Lò Đức Khoa Thực hiện Test Lò Đức Khoa Vũ Danh Mạnh Báo cáo quy trình Test Vũ Danh Mạnh Triển khai Đinh Gia Cương 1 tuần Lập kế hoạch Đinh Gia Cương Lập giải pháp Đinh Gia Cương Cài đặt và vận hành Đinh Gia Cương Đào tạo sử dụng Đinh Gia Cương Báo cáo triển khai Đinh Gia Cương Tổng thời gian 8 tuần 1.4 Kế hoạch triển khai STT Công việc 27/09-01/10 02-08/10 09-23/10 24/10-06/11 07-14/11 15-21/11 1 Xây dựng hợp đồng 2 Xác định yêu cầu 3 Phân tích thiết kế 4 Lập trình 5 Test 6 Qui trình triển khai 2. Quy trình xây dựng hợp đồng phần mềm CỘNG HÒA XÃ HỘI CHỦ NGHĨA VIỆT NAM Độc lập - Tự do – Hạnh phúc -----o0o----- HỢP ĐỒNG KINH DOANH PHẦN MỀM Số 14/HĐPM -Căn cứ vào Bộ luật dân sự của nước Cộng Hòa Xã Hội Chủ Nghĩa Việt Nam được Quốc Hội khóa 11 thông qua ngày 14/6/2005 -Căn cứ vào luõt thương mại số 36/2005/QH11 của nước Cộng Hòa Xã Hội Chủ Nghĩa Việt Nam được Quốc Hội khóa 11 thông qua ngày 14/6/2005 - Căn cứ vào nghị định Nghị định 47/NĐ-CP có hiệu lực từ 30/6/2009 về bảo vệ phần mềm máy tính - Căn cứ vào Pháp lệnh 04/2008/UBTVQH12 về sở hữu trí tuệ có hiệu lực từ ngày 1/8/2008 - Căn cứ Luật Công nghệ thông tin ngày 29 tháng 6 năm 2006 -Căn cứ Quyết định số 246/2005/QĐ-TTg ngày 06 tháng 10 năm 2005 của Thủ tướng Chính phủ về việc phê duyệt Chiến lược phát triển công nghệ thông tin và truyền thông đến năm 2010 và định hướng đến năm 2020 -Sau khi xem xét yêu cầu của Công ty kho gỗ ván ép của chi nhánh công ty MDF Gia Lai và khả năng cung cấp dịch vụ của Nhóm xây dựng phần mềm Quản lý kho. Hôm nay Ngày 27 Tháng 10 Năm 2009, chúng tôi gồm BấN A: Công ty kho gỗ ván ép của chi nhánh công ty MDF Gia Lai Địa chỉ: Số 32-Đại Từ-Đại Kim-Hà Nội Điện thoại: 04.35400826 Fax : 04.6283690 Đại diện: Đinh Ngọc Xuân Chức vụ: Giám đốc Mã số thuế: 5900227820-003 Tài khoản: 1460431101000348 Mở tại: Ngân hàng NN&PTNT Nam – Hà Nội BấN B: NHểM XÂY DỰNG PHẦM MỀM QUẢN LÝ KHO Địa chỉ: Số 207 - Giải Phóng- Hai Bà Trưng – Hà Nội Điện thoại: 0986148893 Fax………………………… Đại diện: Thiều Quang Huy Chức vụ :Quản trị viên dự án Mã số thuế: ………. Email: ……… Hai bên thỏa thuận ký kết hợp đồng với những nội dung như sau: Điều 1 : Nội dung hợp đồng Bên B cung cấp cho bên A những dịch vụ như sau: Số TT Tên dịch vụ Ghi chú 1 Phần mềm QL kho 2 Tạo tài khoản cập nhật dữ liệu 3 Duy trì tài khoản cập nhật dữ liệu 4 Giới thiệu phần mềm Miễn phí 5 Hướng dẫn sử dụng Miễn phí 6 Tư vấn miễn phí về phần mềm Miễn phí 7 Tìm kiếm Miễn phí 8 Liên hệ Miễn phí 9 Ngôn ngữ Tiếng Việt Miễn phí 10 Cài đặt triển khai hoàn chỉnh Điều 2: Giá trị hợp đồng và thanh toán (chưa bao gồm thuế VAT) 2.1 Chi phí toàn bộ phần mềm: 5.600.000 VND (Bằng chữ: Năm triệu sáu trăm đồng chẵn) 2.2 Phương thức thanh toán: Thanh toán bằng tiền đồng Việt Nam(thanh toán bằng tiền mặt,ngõn phiếu sec hoặc chuyển khoản) 2.3 Lịch trình thanh toán: Chi phí xây dựng phần mềm sẽ thanh toan 60% ngay sau khi ký kết hợp đồng,cũn lại 40% thanh toán ngay sau khi cỏc bờn ký vào Biên bản thanh lý hợp đồng phân mềm. Điều 3: Trách nhiệm và quyền hạn của mụĩ bờn 3.1 Trách nhiệm quyền hạn của bên A: -Cung cấp thông tin đảm bảo chính xác ,trung thực trong khuôn khổ pháp luật quy định -Có trách nhiệm thanh toán các khoản chi phí theo như quy định tại điều 2 nói trên. -Có quyền khiếu nại về chất lượng thông tin,chất lượng dịch vụ do bên B cung cấp.Mọi khiếu nại phải được gửi cho Bên B dưới dạng văn bản trong vòng 5 ngày kể từ ngày phát sinh vấn đề và Bên B trả lời khiếu nại cho bên A trong vòng 5 ngày kể từ ngày Bên B nhận được công văn của bên A 3.2 Trách nhiệm quyền hạn của Bên B -Cung cấp các dịch vụ theo Điều 1 của Hợp đồng này -Có quyền tạm ngưng phục vụ nếu Bên A thanh toán chậm quá 10 ngày kể từ ngày bàn giao kỹ thuật ch bên B -Trong vòng 30 ngày kể từ ngày ký bên B sẽ cung cấp sản phẩm hoàn thiện cho bên A Điều 4: Bảo hành 4.1 Bên B có trách nhiệm bảo hành về các lỗi kỹ thuật và tư vấn trực tiếp,qua điện thoại hoặc qua fax cho Bên A trong thời gian 12 tháng kể từ ngày bàn giao phần mềm hoàn chỉnh 4.2 Sau khi hết hạn bảo hành Bên B tư vấn miễm phí cho Bên A qua điện thoại, Mail hoặc fax nếu có vưỡng mắc về kỹ thuật. Điều 5: Điều khoản chung 5.1 Hai bên cam kết thực hiện đúng nghiac vụ của mình theo các điều khoản dã ghi trong hợp đồng 5.2 Trong quá trình thực hiện hợp đồng, nếu có bất kỳ vấn đề nào phát sinh hai bên cùng trao đổi, giả quyết trrn tinh thần hợp tác giúp đỡ lẫn nhau 5.3 Nêu cú tranh chấp xảy ra thì mọi vấn đề không thống nhất sẽ được giải quýờt theo quy định của pháp luật 5.5 Hợp đồng này gồm 5 trang ,được lập thành 2 bản có giá trị pháp lý như nhau .Mỗi bên giữ 1 bản và có hiệu lực từ ngày ký. Hà Nội,Ngày 27 Tháng 10 Năm 2009 ĐẠI DIỆN BấN A ĐẠI DIỆN BấN B (Ký tên, đóng dấu) (Ký tên, đóng dấu) PHỤ LỤC 1: CÁC MODULE TÍNH NĂNG VÀ YÊU CẦU KỸ THUẬT PHẦN MỀM QUẢN LÝ KHO HÀNG No Items Quantity Unit price (VND) Amount (VND) VAT 1 Thiết kế giao diện chính Hệ thống Cập nhật danh mục Quản lý Báo cáo Trợ giúp 01 package 1.000.000 1.000.000 0% 2 Module Hệ thống Đăng nhập Quản lý user 01 module 500.000 500.000 0% 3 Module cập nhật danh mục Cập nhật danh mục 01 module 500.000 500.000 0% 4 Module Quản lý Cập nhật phiếu nhập Cập nhật phiếu xuất Quản lý tồn kho 01 module 2.000.000 2.000.000 0% 5 Module Báo cáo Báo cáo nhập kho Báo cáo tồn kho Báo cáo xuất nhập tồn 01 module 800.000 800.000 0% 7 Module Help 01 module 200.000 200.000 0% Tổng: 5.000.000 Bằng chữ: Năm triệu đồng Miễn phí bảo trì vĩnh viễn. Miễn phí đào tạo, hướng dẫn vận hành, quản lý phần mềm. 3. Quy trình xác định yêu cầu Mục đích: sau khi đó cú hợp đồng với khách hàng, hợp đồng được chuyển sang để thực hiện chương trình thứ hai nhằm xác định nhu cầu của khách hang về sản phẩm tương lai. Yêu cầu đặt ra là phải lượng hoá được các dạng mô hình. Các giai đoạn Lập kế hoạch xác định yêu cầu Xác định yêu cầu của người sử dụng Phân tích nghiệp vụ Lập mô hình hệ thống Báo cáo quy trình 2 3.1 Lập kế hoạch STT Công Việc Nhân lực (Người) Thời gian (ngày) Người/ngày 1 Xác định yêu cầu người sử dụng 2 2 4 2 Phân tích nghiệp vụ 2 2 4 3 Lập mô hình hệ thống 2 2 4 4 Báo cáo quy trình 2 1 1 1 3.2 Khảo sát và xác định yêu cầu người sử dụng 3.2.1 Sơ đồ tổ chức của chi nhánh công ty ván gỗ ép MDF Gia Lai Ban giám đốc Kho Phòng kế toán Chi trả lương Thanh toán hoá đơn Kiểm tra hàng hóa Xác định kết quả kinh doanh Lưu trữ hàng hóa Quản lý hàng hóa 3.2.2 Yêu cầu chức năng nghiệp vụ a. Kho Quản lý hàng nhập Quản lý hàng xuất Quản lý hàng tồn b. Phũng kế toán Yêu cầu các báo cáo thường kì về hàng hóa trong kho. 3.2.3 Yêu cầu chức năng hệ thống - Phân quyền: Với mỗi chức danh khác nhau thỡ cỏc chức năng của phần mềm có giới hạn khác nhau. Quyền admin thì lớn hơn quyền user - Cấu hình thiết bị: Máy cá nhân phải được trang bị cấu hình phần cứng mạnh, chạy hệ điều hành Windows XP trở lên. 3.2.4 Yêu cầu phi chức năng - Giao diện trực quan, thân thiện, dễ sử dụng. - Khả năng quản lý linh hoạt: Cho phép thêm mới, sửa chữa, cập nhật nhanh chóng, chính xác. - Khả năng tìm kiếm đa khoá: Sử dụng nhiều khoá để có thể tìm kiếm chính xác nhất. - Khả năng báo cáo tuỳ biến: Cho phép người dùng lựa chọn cỏc tiờu thức theo ý mình để in báo cáo - Tự động hoỏ cỏc công việc diễn ra hàng ngày: như phân bổ chuyến đi, cập nhật xe về bến, nhắc nhở bảo dưỡng, sửa chữa. 3.3 Phân tích nghiệp vụ chuyên sâu 3.3.1. Nhập kho : Bước 1 : Phòng kế toán chuyển đơn đặt hàng và bảng kê xuống kho ( đây là đơn đặt hàng của chi nhánh gửi vào trong tổng công ty MDF Gia Lai có ghi rõ chủng loại và khối lượng gỗ cần đặt ) Bước 2 : Kho kiểm kê hàng theo bảng kê, kiểm tra số lượng và chất lượng của ván sau đó ghi xác nhận giao nhận hàng vào phần dưới của bảng kê Bước 3 : Viết phiếu nhập kho 3.3.2.Xuất kho : Bước 1 : Kho nhận hóa đơn và bảng kê từ phòng kế toán Bước 2 : Kho viết phiếu xuất kho : phiếu này gồm có 3 liên : 1 gửi lên phòng kế toán, 1 do kho giữ, 1 đưa cho khách hàng Bước 3 : Khách hàng kiểm tra hàng theo đúng bảng kê sau đó ghi xác nhận giao nhận hàng vào phần dưới bảng kê Bước 4 : Kho chuyển phiếu xuất kho lên cho phòng kế toán 3.4 Mô tả hoạt động hệ thống 3.4.1 Sơ đồ BFD QUẢN LÝ KHO GỖ CHI NHÁNH CÔNG TY MDF GIA LAI Quản lý hàng nhập Quản lý hàng xuất Lập báo cáo Nhận bảng kê từ P.KT Kiểm tra hàng nhập Xếp hàng vào kho Xác nhận nhập hàng Nhận bảng kê từ P.KT Gửi phiếu nhập kho lên P.KT Viết phiếu xuất kho Lưu phiếu xuất kho Gửi phiếu xuất kho lên Khách hàng Giao hàng Gửi phiếu xuất kho lên P.KT Lập báo cáo định kỳ Lập báo cáo theo yêu cầu Lưu phiếu nhập kho Kiểm tra lýợng tồn & Báo cáo lên P.KT 3.4.2 Sơ đồ DFD 3.4.2.1 Sơ đồ mức ngữ cảnh Quản Lý Kho Gỗ Chi Nhánh Công Ty MDF GIA LAI Khách Hàng Tổng Công Ty MDF GIA LAI Công Nhân Viên Trong Kho Giám Đốc Chi Nhánh CSDL Công Ty Chi Nhánh 3.4.2.2 Sơ đồ DFD mức 0 3.4.3 Sơ đồ DFD mức 1 3.4.3.1 Sơ đồ DFD mức 1 Quản lý phiếu nhập. 3.4.3.2 Sơ đồ DFD mức 1 Quản lý phiếu xuất. 3.4.3.3 Sơ đồ DFD mức 1 Báo cáo 3.5 Báo cáo quy trình xác định yêu cầu Ta thu được các bản phân tích nghiệp vụ, phân tích yêu cầu của người sử dụng và tổng quan về hoạt động của hệ thống cũng như các sơ đồ BFD, DFD là đầu vào của quy trình phân tích thiết kế. 4. Quy trình phân tích thiết kế 4.1 Lập kế hoạch thiết kế STT Công việc Nhân lực (Người) Thời gian (ngày) Người/ngày 1 Thiết kế kiến trúc 1 2 2 2 Thiết kế dữ liệu 1 5 5 3 Thiết kế thủ tục 1 2 2 4 Thiết kế giao diện 1 4 4 4.2 Thiết kế kiến trúc 4.3 Thiết kế dữ liệu 4.3.1 Sơ đồ cấu trúc dữ liệu DSD 4.3.2 Thiết kế các bảng CSDL 4.3.2.1 Bảng người dùng STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 User Text 24 Người Đăng Nhập 3 Pass Text 16 Mật khẩu 4 Quyen Text 30 Quyền Hạn Người Đăng nhập 4.3.2.2 Bảng nhân viên STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaNV Text 10 Mã Nhân Viên 2 TenNV Text 25 Tên Nhân Viên 3 NgaySinh Date Ngày Sinh 4 CMTND Number 12 Chứng minh thư nhân dân 5 QueQuan Text 30 Quê Quán 6 DiaChi Text 50 Địa Chỉ 7 SDT Number 20 Số Điện Thoại 4.3.2.3 Bảng khách hàng STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaKH Text 10 Mã Khách Hàng 2 TenKH Text 25 Tên Khách Hàng 3 DiaChi Text 30 Địa Chỉ 4 SDT Number 20 Số điện thoại 5 Fax Number 12 Số fax 6 TaiKhoan Number 12 Tài Khoản 7 MaSoThue Number 10 Mã số thuế 4.3.2.4 Bảng mặt hàng STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaMH Text 10 Mã Mặt Hàng 2 TenMH Text 25 Tên Mặt Hàng 3 DVT Text 10 Đơn vị tính 5 GhiChu Text 50 Ghi Chú 4.2.3.5 Bảng phiếu nhập STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaPNK Text 10 Mã Phiếu Nhập Kho 2 LyDoNhap Text 5 Lý Do Nhập 3 MaNV Text 7 Mã Nhân Viên 4 TongTien Number 10 Tổng tiền 5 NgayThang Date Ngày Tháng 4.3.2.6 Bảng phiếu xuất STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaPXK Text 10 Mã Phiếu Nhập Kho 2 MaKH Text 10 Mã Khách Hàng 3 LiDoXuat Text 50 Lý Do Xuất 4 MaNV Text 10 Mã Nhân Viên 5 TongTien Text 10 Tổng Tiền 6 NgayThang Date  dd/mm/yyyy Ngày Tháng 4.3.2.7 Bảng phiếu nhập kho chi tiết STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaPNKCT Text 10 Mã Phiếu Nhập Kho Chi Tiết 2 MaPNK Text 10 Mã Phiếu Nhập Kho 3 MaMH Text 10 Mã Mặt Hàng 4 TenMH Text 50 Tên Mặt Hàng 5 DVT Text 10 Đơn Vị Tính 6 SLNhapYC Number 4 Số Lượng Nhập Theo Yêu Cầu 7 SLNhapTT Number 4 Số Lượng Nhập Thực Tế 8 DonGia Number 7 Đơn Giá 4.3.2.8 Bảng phiếu xuất kho chi tiết STT Tên Trường Kiểu Dữ Liệu Độ Rộng Diễn Giải 1 MaPXKCT Text 10 Mã Phiếu Xuất Kho Chi Tiết 2 MaPXK Text 10 Mã Phiếu Xuất Kho 3 MaMH Text 10 Mã Mặt Hàng 4 TenMH Text 50 Tên Mặt Hàng 5 DVT Text 10 Đơn Vị Tính 6 SLXuatYC Number 4 Số Lượng Xuất Theo Yêu Cầu 7 SLXuatTT Number 4 Số Lượng Xuất Thực Tế 8 DonGia Number 7 Đơn Giá 4.4 Thiết kế giải thuật 4.4.1 Giải thuật đăng nhập 4.4.2 Giải thuật cập nhật dữ liệu 4.4.3 Giải thuật xuất báo cáo 4.5 Thiết kế giao diện 4.5.1 Giao diện của chương trình 4.5.2 Form đăng nhập 4.5.3 Các menu của chương trình - Menu Hệ thống Menu cập nhật danh mục Menu Quản lý Menu Quản lý báo cáo - Menu trợ giúp 4.5.4 Form quản lý người dùng mới 4.5.5 Form đổi mật khẩu 4.5.6 Form danh mục khách hàng 4.5.6 Form danh mục mặt hàng 4.5.7 Form danh mục nhân viên 4.5.8 Form quản lý danh sách phiếu nhập 4.5.9 Form quản lý danh sách phiếu xuất 3 4.5.10 Form phiếu nhập 4.5.11 Form phiếu xuất 4.5.12 Form báo cáo nhập kho 4.5.13 Form báo cáo xuất kho 4.5.14 Form báo cáo xuất nhập tồn 4.5.14 Form hướng dẫn 4.5.15 Giới thiệu phần mềm 5. Quy trình lập trình 5.1 Lập kế hoạch lập trình STT Công việc Nhân lực (Người) Thời gian (ngày) Người/ngày 1 Lập trình hệ thống 1 2 3 2 Cập nhật danh mục 1 3 3 3 Xử lý nghiệp vụ 2 4 8 4 Tìm kiếm báo cáo 1 4 4 - Sử dụng ngôn ngữ Visual Basic 6.0 và hệ quản trị cơ sở dữ liệu Microsoft Access 2003. - Sử dụng phần mềm Crystal Report 8.5 để thiết kế báo cáo. - Sử dụng phần mềm Help and Menual 11 để tạo Help File. - Sử dụng phần mềm InstallShield 12 để tạo bộ cài đặt. 5.2 Lập trình cập nhật danh mục Đoạn code cho phép cập nhật danh mục chính xác. Có bẫy nhiều lỗi và đảm bảo độ an toàn của thông tin nhập liệu. - Với giao diện như sau Code của form mặt hàng Dim bStatus As Boolean, bAdd As Boolean Dim sFilter As String Private Sub cmdCancel_Click() bStatus = False Reset_Form True Grid.Enabled = True cmdFilter.Default = True cmdThoat.Cancel = True End Sub Private Sub cmdFilter_Click() sFilter = "" If txtFilter.Text "" Then Select Case cboFilter.ListIndex Case 0: sFilter = "" Case 1: sFilter = " WHERE MaMH LIKE '%" & txtFilter.Text & "%'" Case 2: sFilter = " WHERE TenMH LIKE '" & txtFilter.Text & "%'" Case 3: sFilter = " WHERE DVT LIKE '%" & txtFilter.Text & "%'" Case 4: sFilter = " WHERE GhiChu LIKE '%" & txtFilter.Text & "%'" End Select End If loadGrid sFilter End Sub Private Sub cmdSave_Click() If txtTen.Text = "" Then MsgBox "Hay nhap ten mat hang", vbOKOnly, "Chu y" Exit Sub End If If txtDVT.Text = "" Then MsgBox "Hay nhap don vi tinh", vbOKOnly, "Chu y" Exit Sub End If If txtGhiChu.Text = "" Then MsgBox "Hay nhap ghi chu", vbOKOnly, "Chu y" Exit Sub End If If bAdd Then Them Else: Sua bStatus = False Reset_Form True Grid.Enabled = True End Sub Private Sub cmdSua_Click() bAdd = False bStatus = True Reset_Form False Grid.Enabled = True cmdSave.Default = True cmdCancel.Cancel = True txtTen.SetFocus End Sub Private Sub cmdThem_Click() bAdd = True bStatus = True Reset_Form True Grid.Enabled = False cmdSave.Default = True cmdCancel.Cancel = True txtTen.SetFocus End Sub Private Sub cmdThoat_Click() Unload Me End Sub Private Sub cmdXoa_Click() Xoa End Sub Private Sub Form_Load() CenterMDI frmmain, Me cboFilter.AddItem "Tất cả", 0 cboFilter.AddItem "Mã mặt hàng", 1 cboFilter.AddItem "Tên mặt hàng", 2 cboFilter.AddItem "Đơn vị tính", 3 cboFilter.AddItem "Ghi chó", 4 cboFilter.ListIndex = 0 txtID.Locked = True bStatus = False Reset_Form True loadGrid End Sub Private Sub loadGrid(Optional sFil As String = "") Grid.clear Grid.FormatString = "STT" & "|Mã mặt hàng " & Space(0) & "|Tên mặt hàng" & Space(26) & "|Đơn vị tính" & Space(0) & "|Ghi chó" & Space(40) Grid.Rows = 1 OpenDB "SELECT *" & _ " FROM MatHang" & sFil Do While Not rs.EOF Grid.AddItem Grid.Rows & vbTab & rs!MaMH & vbTab & rs!TenMH & vbTab & rs!DVT & vbTab & rs!GhiChu, Grid.Rows rs.MoveNext Loop CloseDB If sFil = "" Then cboFilter.ListIndex = 0 End Sub Private Sub Reset_Form(clear As Boolean) If clear Then txtID.Text = "" txtTen.Text = "" txtDVT.Text = "" txtGhiChu.Text = "" End If txtTen.Locked = Not bStatus txtDVT.Locked = Not bStatus txtGhiChu.Locked = Not bStatus cmdThem.Enabled = Not bStatus cmdSua.Enabled = Not bStatus cmdXoa.Enabled = Not bStatus cmdSave.Enabled = bStatus cmdCancel.Enabled = bStatus End Sub Private Sub Grid_SelChange() txtID.Text = Grid.TextMatrix(Grid.Row, 1) txtTen.Text = Grid.TextMatrix(Grid.Row, 2) txtDVT.Text = Grid.TextMatrix(Grid.Row, 3) txtGhiChu.Text = Grid.TextMatrix(Grid.Row, 4) End Sub Private Sub Them() OpenDB "select * from MatHang" txtID.Text = CreateID("MaMH", rs, "MH0001") rs.AddNew rs!MaMH = txtID.Text rs!TenMH = txtTen.Text rs!GhiChu = txtGhiChu.Text rs!DVT = txtDVT.Text rs.Update CloseDB Reset_Form True loadGrid End Sub Private Sub Sua() If txtID.Text = "" Then Exit Sub OpenDB "select * from MatHang where MaMH='" & txtID.Text & "'" 'Update rs!TenMH = txtTen.Text rs!GhiChu = txtGhiChu.Text rs!DVT = txtDVT.Text rs.Update CloseDB Reset_Form True loadGrid sFilter End Sub Private Sub Xoa() If txtID.Text = "" Then Exit Sub If MsgBox("Bạn có muốn xóa mặt hàng có MaMH = " & txtID.Text & " không?.", vbYesNo + vbCritical, "Thông báo!") = vbYes Then OpenDB "select * from MatHang where MaMH='" & txtID.Text & "'" 'Delete rs.Delete CloseDB Reset_Form True loadGrid End If End Sub 5.3 Lập trình form phiếu nhập Đoạn code cho phép cập nhật phiếu nhập. Đáp ứng được yêu cầu cập nhật một phiếu nhập mới hoặc sửa phiếu đã nhập - Với giao diện như sau Code của form phiếu nhập. Dim bStatus As Boolean, bAdd As Boolean Dim sFilter As String Dim rsnv As New ADODB.Recordset Dim rshang As New ADODB.Recordset Dim rs1 As New ADODB.Recordset Private Sub cbo1_Change() If cbo1.Text "" Then OpenDB "select * from MatHang where MaMH='" & cbo1.Text & "'" txttenMH.Text = rs.Fields("TenMH") txtdvt.Text = rs.Fields("DVT") CloseDB End If End Sub Private Sub cbo1_Click() If cbo1.Text "" Then OpenDB "select * from MatHang where MaMH='" & cbo1.Text & "'" txttenMH.Text = rs.Fields("TenMH") txtdvt.Text = rs.Fields("DVT") CloseDB txtnhapyc.SetFocus End If End Sub Private Sub cbo2_change() If cbo2.Text "" Then rs1.Open " SELECT * FROM NhanVien WHERE MaNV='" & cbo2.Text & "' ", cn, adOpenDynamic, adLockOptimistic txttennv.Text = rs1.Fields("TenNV") rs1.Close End If End Sub Private Sub cbo2_Click() If cbo2.Text "" Then rs1.Open " SELECT * FROM NhanVien WHERE MaNV='" & cbo2.Text & "' ", cn, adOpenDynamic, adLockOptimistic txttennv.Text = rs1.Fields("TenNV") rs1.Close End If End Sub Private Sub cmdCancel_Click() bStatus = False Reset_Form True Grid.Enabled = True ' cmdFilter.Default = True cmdThoat.Cancel = True End Sub Private Sub cmdSave_Click() If txtnhapyc.Text = "" Then MsgBox " Bạn cần nhập S/L yêu cầu", vbExclamation, "Chó ý" Exit Sub End If If txtnhaptt.Text = "" Then MsgBox " Bạn cần nhập S/L thực tế", vbExclamation, "Chó ý" Exit Sub End If If txtdongia.Text = "" Then MsgBox " Bạn cần nhập đơn giá", vbExclamation, "Chó ý" Exit Sub End If If txtngaythang.Text = "" Then MsgBox " Bạn cần nhập ngày tháng", vbExclamation, "Chó ý" Exit Sub End If If txttennv.Text = "" Then MsgBox " Bạn cần chọn nhân viên ", vbExclamation, "Chó ý" Exit Sub End If cmdSavehd_Click If bAdd Then Them Else: Sua bStatus = False Reset_Form True ' Tinh tong tien OpenDB "Select sum(ThanhTien) from PNKchitiet where MaPNK='" & txtID.Text & "'" txttongtien.Text = rs.Fields(0) CloseDB ' Update tong tien OpenDB "select * from PhieuNhap where MaPNK='" & txtID.Text & "'" rs!tongtien = txttongtien.Text rs.Update CloseDB Grid.Enabled = True End Sub Private Sub cmdSavehd_Click() If badd1 Then Themhd End If End Sub Private Sub cmdSua_Click() bAdd = False bStatus = True cbo2.Locked = True cbo1.Locked = True txtngaythang.Locked = True txtlido.Locked = True Reset_Form False Grid.Enabled = True cmdSave.Default = True cmdCancel.Cancel = True End Sub Private Sub cmdThem_Click() bAdd = True bStatus = True Reset_Form True cbo1.Locked = False Grid.Enabled = False cmdSave.Default = True cmdCancel.Cancel = True End Sub Private Sub cmdThoat_Click() frmlistphieunhap.Show Unload Me rsnv.Close rshang.Close End Sub Private Sub cmdXoa_Click() Xoa End Sub Private Sub Xoa() If cbo1.Text = "" Then Exit Sub If MsgBox("Xoa mat hang co MaMH = " & cbo1.Text & " khong?.", vbYesNo + vbCritical, "Xac nhan xoa!") = vbYes Then OpenDB "select * from PNKchitiet where MaMH='" & cbo1.Text & "' and MaPNK='" & txtID.Text & "'" 'Delete rs.Delete CloseDB OpenDB "select * from BieuGhi where MaMH='" & cbo1.Text & "' and MaPNK='" & txtID.Text & "'" rs.Delete CloseDB Reset_Form True End If tongtien sFilter = " WHERE MaPNK = '" & txtID.Text & "'" loadGrid sFilter Grid.Refresh End Sub Private Sub Form_Activate() sFilter = " WHERE MaPNK = '" & txtID.Text & "'" loadGrid sFilter End Sub Private Sub Form_Load() 'SetFont Me CenterMDI frmmain, Me If badd1 = True Then OpenDB "select * from PNKchitiet" txtID.Text = CreateID("MaPNK", rs, "PNK0001") CloseDB End If bStatus = False Reset_Form True rsnv.CursorLocation = adUseClient rsnv.Open "Select * from NhanVien", cn, adOpenDynamic, adLockOptimistic rshang.CursorLocation = adUseClient rshang.Open "select * from MatHang", cn, adOpenDynamic, adLockOptimistic gandulieu txttongtien.Locked = True txtthanhtien.Locked = True txtID.Locked = True txttennv.Locked = True txtdvt.Locked = True End Sub Private Sub loadGrid(Optional sFil As String = "") Grid.clear Grid.FormatString = "STT" & "|Mã mặt hàng " & Space(0) & "|Tên mặt hàng" & Space(9) & "|DVT" & Space(2) & "|SL yêu cầu" & Space(1) & "|SL thực tế" & Space(2) & "|Đơn giá" & Space(7) & "|Thành tiền" & Space(15) Grid.Rows = 1 OpenDB "SELECT *" & _ " FROM PNKchitiet" & sFil Do While Not rs.EOF Grid.AddItem Grid.Rows & vbTab & rs!MaMH & vbTab & rs!TenMH & vbTab & rs!DVT & vbTab & rs!SLnhapYC & vbTab & rs!SLnhapTT & vbTab & rs!DonGia & vbTab & rs!ThanhTien, Grid.Rows rs.MoveNext Loop CloseDB End Sub Private Sub Reset_Form(clear As Boolean) If clear Then cbo1.Text = "" txttenMH.Text = "" txtdvt.Text = "" txtnhapyc.Text = "" txtnhaptt.Text = "" txtdongia.Text = "" txtthanhtien.Text = "" End If txttenMH.Locked = Not bStatus txtdvt.Locked = Not bStatus txtnhapyc.Locked = Not bStatus txtnhaptt.Locked = Not bStatus txtdongia.Locked = Not bStatus txtthanhtien.Locked = Not bStatus cmdThem.Enabled = Not bStatus cmdSua.Enabled = Not bStatus cmdXoa.Enabled = Not bStatus cmdSave.Enabled = bStatus cmdCancel.Enabled = bStatus End Sub Private Sub Grid_SelChange() cbo1.Text = Grid.TextMatrix(Grid.Row, 1) txttenMH.Text = Grid.TextMatrix(Grid.Row, 2) txtdvt.Text = Grid.TextMatrix(Grid.Row, 3) txtnhapyc.Text = Grid.TextMatrix(Grid.Row, 4) txtnhaptt.Text = Grid.TextMatrix(Grid.Row, 5) txtdongia.Text = Grid.TextMatrix(Grid.Row, 6) txtthanhtien.Text = Grid.TextMatrix(Grid.Row, 7) End Sub Private Sub Themhd() OpenDB "select * from PhieuNhap" Do While Not rs.EOF If rs!MaPNK = txtID.Text Then Exit Sub End If rs.MoveNext Loop rs.AddNew rs!MaPNK = txtID.Text rs!Ngaythang = txtngaythang.Text rs!LiDoNhap = txtlido.Text rs!MaNV = cbo2.Text ' rs!TongTien = txttongtien.Text rs.Update CloseDB 'Reset_Form True 'loadGrid End Sub Private Sub Them() OpenDB "select * from PNKchitiet where MaPNK='" & txtID.Text & "'" Do While Not rs.EOF If rs!MaMH = cbo1.Text Then rs!SLnhapYC = rs.Fields(4).Value + txtnhapyc.Text rs!SLnhapTT = rs.Fields(5).Value + txtnhaptt.Text rs!ThanhTien = rs.Fields(7).Value + txtthanhtien.Text rs.Update CloseDB ' Cap nhat vao bieu ghi OpenDB "select * from BieuGhi where MaPNK='" & txtID.Text & "' and MaMH='" & cbo1.Text & "'" rs!SLnhapTT = rs.Fields(7).Value + txtnhaptt.Text rs!ThanhTien = rs.Fields(9).Value + txtthanhtien.Text rs.Update CloseDB Reset_Form True sFilter = " WHERE MaPNK = '" & txtID.Text & "'" loadGrid sFilter Exit Sub End If rs.MoveNext Loop rs.AddNew rs!MaPNK = txtID.Text rs!MaMH = cbo1.Text rs!TenMH = txttenMH.Text rs!DVT = txtdvt.Text rs!SLnhapYC = txtnhapyc.Text rs!SLnhapTT = txtnhaptt.Text rs!DonGia = txtdongia.Text rs!ThanhTien = txtthanhtien.Text rs.Update CloseDB ' update vao truong ban ghi OpenDB " select * from BieuGhi " rs.AddNew rs!Nghiepvu = "NK" rs!MaPNK = txtID.Text 'rs!MaPXK = "0" rs!Ngaythang = txtngaythang.Text rs!MaMH = cbo1.Text rs!TenMH = txttenMH.Text rs!SLnhapTT = txtnhaptt.Text rs!ThanhTien = txtthanhtien.Text rs.Update CloseDB Reset_Form True sFilter = " WHERE MaPNK = '" & txtID.Text & "'" loadGrid sFilter End Sub Private Sub Sua() If cbo1.Text = "" Then Exit Sub OpenDB "select * from PNKchitiet where MaMH='" & cbo1.Text & "'" 'Update rs!MaMH = cbo1.Text rs!TenMH = txttenMH.Text rs!DVT = txtdvt.Text rs!SLnhapYC = txtnhapyc.Text rs!SLnhapTT = txtnhaptt.Text rs!DonGia = txtdongia.Text rs!ThanhTien = txtthanhtien.Text rs.Update CloseDB ' update vao bieu ghi OpenDB "select * from BieuGhi where MaPNK='" & txtID.Text & "' and MaMH='" & cbo1.Text & "'" rs!SLnhapTT = txtnhaptt.Text rs!ThanhTien = txtthanhtien.Text rs.Update CloseDB Reset_Form True sFilter = " WHERE MaPNK = '" & txtID.Text & "'" loadGrid sFilter End Sub Private Sub tongtien() ' Tinh tong tien OpenDB "Select sum(ThanhTien) from PNKchitiet where MaPNK = '" & txtID.Text & "' " 'If rs.EOF = rs.BOF Then 'txttongtien.Text = "0" 'CloseDB 'Else txttongtien.Text = rs.Fields(0) CloseDB ' End If ' Update tong tien OpenDB "select * from PhieuNhap where MaPNK='" & txtID.Text & "'" rs!tongtien = txttongtien.Text rs.Update CloseDB End Sub Private Sub gandulieu() 'Gan du lieu cho dcbMahang With rshang .MoveFirst Do While Not (.EOF Or .BOF) cbo1.AddItem (.Fields(0).Value) .MoveNext Loop End With ' Gan du lieu cho dcbManv With rsnv .MoveFirst Do While Not (.EOF Or .BOF) cbo2.AddItem (.Fields(0).Value) .MoveNext Loop End With End Sub Private Sub txtdongia_Change() If txtdongia.Text = "" Or txtnhaptt.Text = "" Then txtthanhtien.Text = "" Exit Sub Else txtthanhtien.Text = txtdongia.Text * txtnhaptt.Text End If End Sub Private Sub txtdongia_KeyPress(KeyAscii As Integer) Dim Tmp As String Tmp = txtdongia.Text Select Case Chr$(KeyAscii) Case "0" To "9", Chr$(8) Case "-" If InStr(1, Tmp, "-") = 0 Then If txtdongia.SelStart > 0 Then KeyAscii = 0 End If Else KeyAscii = 0 End If Case "." If InStr(1, Tmp, ".") > 0 Then KeyAscii = 0 End If Case Else KeyAscii = 0 End Select End Sub Private Sub txtnhaptt_Change() If txtdongia.Text = "" Or txtnhaptt.Text = "" Then txtthanhtien.Text = "" Exit Sub Else txtthanhtien.Text = txtdongia.Text * txtnhaptt.Text End If End Sub Private Sub txtnhaptt_KeyPress(KeyAscii As Integer) Dim Tmp As String Tmp = txtnhaptt.Text Select Case Chr$(KeyAscii) Case "0" To "9", Chr$(8) Case "-" If InStr(1, Tmp, "-") = 0 Then If txtnhaptt.SelStart > 0 Then KeyAscii = 0 End If Else KeyAscii = 0 End If Case "." If InStr(1, Tmp, ".") > 0 Then KeyAscii = 0 End If Case Else KeyAscii = 0 End Select End Sub Private Sub txtnhapyc_KeyPress(KeyAscii As Integer) Dim Tmp As String Tmp = txtnhapyc.Text Select Case Chr$(KeyAscii) Case "0" To "9", Chr$(8) Case "-" If InStr(1, Tmp, "-") = 0 Then If txtnhapyc.SelStart > 0 Then KeyAscii = 0 End If Else KeyAscii = 0 End If Case "." If InStr(1, Tmp, ".") > 0 Then KeyAscii = 0 End If Case Else KeyAscii = 0 End Select End Sub Private Sub txtngaythang_Validate(Cancel As Boolean) Dim d As Variant d = txtngaythang.Text If Not IsDate(d) Then MsgBox "Bạn phải nhập vào ngày hợp lệ" & _ " (vd: 05/06/2009) ", vbCritical, " Nhập ngày hoá đơn" Cancel = True Exit Sub txtngaythang.SetFocus End If End Sub 5.4 Lập trình xuất báo cáo - Giao diện form báo cáo. - Code form báo cáo Dim rsmpnk As New ADODB.Recordset Dim rsmh As New ADODB.Recordset Dim rs1 As New ADODB.Recordset 'Dim rs2 As New ADODB.Recordset Private Sub cbo1_Change() If cbo1.Text "" Then OpenDB "select * from MatHang where MaMH='" & cbo1.Text & "'" txttenmh.Text = rs.Fields("TenMH") CloseDB End If End Sub Private Sub cbo1_Click() If cbo1.Text "" Then OpenDB "select * from MatHang where MaMH='" & cbo1.Text & "'" txttenmh.Text = rs.Fields("TenMH") Text11.Text = rs.Fields("MaMH") CloseDB End If End Sub. Private Sub cbo2_Click() If cbo2.Text "" Then OpenDB "select * from PhieuNhap where MaPNK='" & cbo2.Text & "'" Text12.Text = rs.Fields("MaPNK") CloseDB End If End Sub Private Sub cbo2_change() If cbo2.Text "" Then OpenDB "select * from PhieuNhap where MaPNK='" & cbo2.Text & "'" Text12.Text = rs.Fields("MaPNK") CloseDB End If End Sub Private Sub cmdin_click() Dim rs2 As New ADODB.Recordset If (opt1.Value = False) And (opt2.Value = False) Then MsgBox "Hãy chọn kiểu báo cao", vbOKOnly, "Chu Y" Exit Sub End If If (opt2.Value = True) And (opt1.Value = False) Then If (txttungay.Text = "") Or (txtdenngay.Text = "") Then MsgBox "Hay chon ngay thang", vbOKOnly, "Chu y" Exit Sub End If If cbo1.Text = "" Then MsgBox "Hay chon mat hang", vbOKOnly, "Chu y" Exit Sub End If If (DateValue(txttungay.Text) > DateValue(txtdenngay.Text)) Then MsgBox "Bạn chọn khoảng thời gian không chính xác ", vbOKOnly, "Thông báo!" Exit Sub End If rs2.Open "select Ngaythang,MaPNK,SLNhapTT,MaMH From BieuGhi where Nghiepvu = 'NK' and MaMH= '" & Text11.Text & "' and Ngaythang between Datevalue('" & txttungay.Text & "') and Datevalue('" & txtdenngay.Text & "')", cn, adOpenDynamic, adLockOptimistic cr.ReportFileName = App.Path & "\Report\rp_bcnk1.rpt" cr.SetTablePrivateData 0, 3, rs2 cr.Formulas(1) = "txttungay= '" & txttungay.Text & "'" cr.Formulas(2) = "txtdenngay= '" & txtdenngay.Text & "'" cr.Formulas(3) = "mamh= '" & cbo1.Text & "'" cr.Formulas(4) = "tenmh= '" & txttenmh.Text & "'" cr.WindowState = crptMaximized cr.PrintReport rs2.Close cbo1.Text = "" txttenmh.Text = "" End If If (opt1.Value = True) And (opt2.Value = False) Then If (DateValue(txttungay.Text) > DateValue(txtdenngay.Text)) Then MsgBox "Bạn chọn khoảng thời gian không chính xác ", vbOKOnly, "Thông báo!" Exit Sub End If If (txttungay.Text = "") Or (txtdenngay.Text = "") Then MsgBox "Hay chon ngay thang", vbOKOnly, "Chu y" Else Dim strSQL As String 'Dim rs1 As New ADODB.Recordset strSQL = " select Ngaythang,MaPNK,MaMH,TenMH,SLNhapTT From BieuGhi where Nghiepvu = 'NK' and Ngaythang between Datevalue('" & txttungay.Text & "') and Datevalue('" & txtdenngay.Text & "')" rs1.Open strSQL, cn, adOpenDynamic, adLockOptimistic cr1.ReportFileName = App.Path & "\Report\rp_bcnk.rpt" cr1.SetTablePrivateData 0, 3, rs1 cr1.Formulas(1) = "txttungay= '" & txttungay.Text & "'" cr1.Formulas(2) = "txtdenngay= '" & txtdenngay.Text & "'" cr1.WindowState = crptMaximized cr1.PrintReport rs1.Close End If End If End Sub Private Sub Form_Load() Calendar1.Value = Date Calendar2.Value = Date rsmh.CursorLocation = adUseClient rsmh.Open "select * from MatHang", cn, adOpenDynamic, adLockOptimistic gandulieu Label1.Visible = False Label2.Visible = False cbo1.Visible = False txttenmh.Visible = False End Sub Private Sub gandulieu() 'Gan du lieu cho dcbMahang With rsmh .MoveFirst Do While Not (.EOF Or .BOF) cbo1.AddItem (.Fields(0).Value) .MoveNext Loop End With End Sub Private Sub Form_Unload(Cancel As Integer) Unload Me rsmh.Close End Sub Private Sub Image1_Click(Index As Integer) Set cboOriginator = txttungay Calendar1.Visible = True Calendar1.SetFocus If Not IsNull(cboOriginator) Then Calendar1.Value = cboOriginator.Text Else Calendar1.Value = Date End If End Sub Private Sub Image2_Click(Index As Integer) Set cboOriginator = txtdenngay Calendar2.Visible = True Calendar2.SetFocus If Not IsNull(cboOriginator) Then Calendar2.Value = cboOriginator.Text Else Calendar2.Value = Date End If End Sub Private Sub Calendar1_Click() txttungay.Text = Format(Calendar1.Value, "dd/mm/yyyy") Calendar1.Visible = False End Sub Private Sub Calendar2_Click() txtdenngay.Text = Format(Calendar2.Value, "dd/mm/yyyy") Calendar2.Visible = False End Sub Private Sub opt2_Click() If opt2.Value = True Then Label1.Visible = True Label2.Visible = True cbo1.Visible = True txttenmh.Visible = True End If End Sub Private Sub opt1_Click() If opt1.Value = True Then Label1.Visible = False Label2.Visible = False cbo1.Visible = False txttenmh.Visible = False End If End Sub 6. Quy trình Test 6.1 Lập kế hoạch Test STT Công việc Nhân lực (Người) Thời gian (ngày) Người/ngày 1 Lập kịch bản Test 1 2 2 2 Thực hiện Test 2 4 8 3 Báo cáo quy trình 1 1 1 6.2 Lập kịch bản Test Kịch bản Mục đích Test - case 1 Kiểm tra tính bảo mật của hệ thống Test - case 2 Kiểm tra chức năng Quản lý User Tạo User mới Thay đổi tài khoản Test - case 3 Kiểm tra chức năng cập nhật danh mục Thêm, sửa, xoá, duyệt các bản ghi Chức năng tìm kiếm để sửa chữa Chức năng hiện dữ liệu trên đường lưới Test - case 4 Kiểm tra chức năng Danh sách phiếu nhập Test - case 5 Kiểm tra chức năng Danh sách phiếu xuất Test - case 6 Kiểm tra chức năng tạo báo cáo đa năng Tạo báo cáo theo ý người dùng - Lựa chọn trường lọc báo cáo Test - case 7 Kiểm tra chức năng trợ giúp – hướng dẫn sử dụng 6.3 Nội dung Test 6.3.1 Test - case 1 Kiểm tra tính bảo mật hệ thống Mục đích: Kiểm tra tính bảo mật hệ thống Các bước tiến hành: Bước 1: Khởi động chương trình và màn hình hỏi mật khẩu hiện ra. Bước 2: Nhập không chính xác tên đăng nhập và mật khẩu. Bước 3: Dữ liệu Demo có tên đăng nhập tuananh pass 1. Quyền admin Bước 4: Đăng nhập lại với tên đăng nhập tuananh pass 123. Quyền admin Kết quả dự kiến : Tính bảo mật tốt Kết quả thực tế: Tính bảo mật tốt Bước 1: Khởi động chương trình và màn hình hỏi mật khẩu hiện ra.Nhập mật khảu sai và hiện ra thông báo Bước2: Đăng nhập với user và mật khẩu chính xác 6.3.2 Test - case 2 Kiểm tra chức năng Quản lý User Mục đích: Kiểm tra chức năng Quản lý User Các bước thực hiện Bước 1: Tạo user mới Bước 2: Thay đổi mật khẩu Bước 3: Xem danh mục User Kết quả dự kiến : Các chức năng hoạt động tốt Kết quả thực tế: Các chức năng hoạt động tốt Bước 1 tạo tài khoản mới “NEU” với quyền quản trị. Bước 2: Thay đổi mật khẩu cho tài khoản NEU Xác nhận thay đổi mật khẩu: 6.3.3 Test - case 3 Kiểm tra chức năng cập nhật danh mục Mục đích : Kiểm tra chức năng cập nhật danh mục Bước 1: Thêm mới một danh mục Bước 2: Sửa một danh mục Bước 3: Xoá một danh mục Bước 4: Tìm kiếm để sửa một danh mục Kết quả dự kiến : Các chức năng hoạt động tốt Kết quả thực tế: Các chức năng hoạt động tố Bước 1: Thêm mới một danh mục Nhấn vào nút thêm Cập nhật xong ấn nút lưu Cập nhất thông tin mặt hàng Bước 2: Sửa một danh mục Bước 3: Xoá một danh mục Nút xóa mặt hàng - Hiện thị thông báo cú xóa mặt hàng không Bước 4: Tìm kiếm một danh mục - Chọn kiểu tìm kiếm: -Gừ kí tự cần tìm: 6.3.4 Test - case 4 Kiểm tra danh sách phiếu nhập 6.3.5 Test - case 5 Kiểm tra danh sách phiếu xuất 6.3.6 Test - case 6 Kiểm tra tạo báo cáo Bước 1: Chọn các tham số báo cáo Kết quả in báo cáo: 6.3.7 Test - case 7 Kiểm tra trợ giúp 6.4 Tổng kết quy trình Test Sau khi hoàn thành các kịch bản Test, chương trình đã chạy theo đúng yêu cầu đặt ra. Có thể chuyển sang công đoạn tiếp theo. 7.Quy trình triển khai 7.1 Lập kế hoạch STT Công việc Nhân lực (Người) Thời gian (ngày) Người/ngày 1 Lập giải pháp 1 1 1 2 Cài đặt và vận hành 1 1 1 3 Đào tạo sử dụng 1 4 3 4 Báo cáo triển khai 1 1 1 7.2 Lập giải pháp Phần mềm được viết bằng ngôn ngữ Visual Basic sẽ được đóng gói ra file *.exe để chạy. Phần mềm được đóng gói sẽ gồm 1 đĩa CD bao gồm code và các file để chạy chương trình. Công ty MDF Gia Lai sẽ cho người hướng dẫn nhõn viên phòng quản lý kho cài đặt phần mềm cũng như đào tạo người sử dụng. Sau khi cài đặt, phần mềm sẽ được bảo trì miễn phí cũng như sửa chữa phần mềm nếu có sự cố xảy ra cho công ty trong vũng 6 tháng tiếp theo. 7.3 Cài đặt và vận hành + Địa điểm: Phòng Quản lý kho công ty MDF Gia Lai + Thời gian cài đặt: 9h ngày 15/11/2009 + Số máy được cài: 1 máy. 7.4 Đào tạo sử dụng 7.4.1 Cung cấp sách hướng dẫn sử dụng: Hướng dẫn sử dụng: Phần mềm bao gồm các chức năng: + Đăng nhập hệ thống: Để vào được phần mềm, người dung cần đăng ký tài khoản và mật khẩu. + Chỉ người quản lý mới có quyền tạo thay đổi lưu xoá danh mục tài khoản và mật khẩu của người dùng. + Sau khi đăng nhập, nhõn viên kho có thể cập nhật, sửa, lưu, thay đổi, và xoá các danh mục trong các phõn hệ của chương trình. + Nhõn viên quản lý kho có thể lên báo cáo nhờ sự hỗ trợ của phần mềm để báo cáo với cấp trên. 7.4.2 Đào tạo người sử dụng: + Sáng 20/11/2009 đào tạo cán bộ kỹ thuật cách cài đặt và xử lý những lỗi nhỏ có thể phát sinh. Sau đó sẽ đào tạo cán bộ quản lý về cách kiểm soát, quản trị và sử dụng phần mềm. + Chiều 20/11/2009 sẽ đào tạo nhõn viên phòng quản lý kho với các chức năng. 7.5 Báo cáo triển khai Phần mềm được cài đặt tại công ty đã chạy tốt. Người sử dụng đã nắm được cách sử dụng phần mềm. Cán bộ triển khai và đại diện công ty ký kết biên bản triển khai với các nội dung sau đõy: CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM Độc lập - Tự do - Hạnh phúc Hà Nội, ngày 15/11/2009 BIÊN BẢN TRIỂN KHAI Chi nhánh công ty ván gỗ ép MDF Gia Lai (gọi tắt là “Bên A”) Địa chỉ : 32 – Đại Từ - Đại Kim – Hà Nội Điện thoại : 04.35400826 Người đại diện : Đinh Ngọc Xuân Chức vụ : Giám đốc chi nhánh Nhóm 3 Tin học 48 ( gọi tắt là “Bên B” ) Địa chỉ : 207 Giải Phóng - Hai Bà Trưng - Hà Nội Người đại diện : Đinh Gia Cương Chức vụ : Cán bộ triển khai Trong ngày15/11/2009, tôi (Bên B ) là cán bộ triển khai của nhóm 3 lớp tin học kinh tế 48, được cử xuống chi nhánh công ty ván gỗ MDF Gia Lai tiến hành cài đặt và chạy thử phần mềm. Sau khi phần mềm đã chạy ổn định, chúng tôi tiến hành bàn giao phần mềm cho công ty (Bên A ) bao gồm 01 đĩa CD. Ngày 15/11/2009, chúng tôi tiến hành đào tạo cho nhõn viên của công ty về cách cài đặt cũng như cách sử dụng phần mềm. Cả 2 bên đều đồng ý đã hoàn thành quá trình triển khai đúng tiến độ của dự án như đã thoả thuận trong hợp đồng. Đại diện bên A Đại diện bên B CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM Độc lập - Tự do - Hạnh phúc Hà Nội, ngày 20/11/2009 BIÊN BẢN THANH LÝ HỢP ĐỒNG PHẦN MỀM I. Chi nhánh công ty ván gỗ ép MDF GiaLai ( Gọi tắt là “Bờn A” ) Địa chỉ : 32 – Đại Từ - Đại Kim – Hà Nội Điện thoại : 04.35400826 Fax : 04.35400826 Người đại diện : Đinh Ngọc Xuân Chức vụ : Giám đốc chi nhánh II. Nhóm3 Tin học kinh tế 48 (Gọi tắt là “Bờn B”) Địa chỉ : 207 Giải Phóng - Hai Bà Trưng - Hà Nội Điện thoại : 04 36616186 Fax : 04 36616186 Người đại diện : Thiều Quang Huy Chức vụ : Quản trị viên Hôm nay, ngày 20/11/2009 chúng tôi gồm Thiều Quang Huy(đại diện bên B) và Đinh Ngọc Xuân (đại diện bên A ). Thống nhất các điều khoản sau: 1. Phần mềm do bên B cài đặt và bàn giao ngày 15.11.2009 sau 1,5 tháng đã hoạt động ổn định đúng cam kết trong hợp đồng. 2. Hai bên thoả thuận thanh lý hợp đồng. Bên B vẫn sẽ chịu trách nhiệm bảo hành phần mềm trong vòng 1 năm tớnh từ ngày 20.11.2008. 3. Biên bản thanh lý hợp đồng sẽ được in ra làm 2 bản, mỗi bên giữ một bản. Đại diện bên A Đại diện bên B

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

  • docdoko_vn_bai_tap_nhom_xay_dung_phan_me_6656.doc
Luận văn liên quan