Do đặc thù trong lĩnh vực sản xuất kinh doanh của công ty là sản xuất và kinh doanh các loại gạch men và gạch ốp lát, có nhiều loại hàng, nhóm hàng nên việc quản lý sản phẩm tại công ty có nhiều khó khăn. Qui trình sản xuất và kinh doanh của công ty cũng có những đặc thù riêng nên việc quản lý tiêu thụ sản phẩm của công ty được thực hiên hầu hết qua các kênh phân phối là các đại lý và các cửa hàng kinh doanh. Đề tài “phân tích và thiết kế hệ thống thông tin quản lý bán hàng tại công ty Gạch ốp lát Hà Nội” đã được khảo sát thực tế tại công ty Gạch ốp lát Hà Nội nên đã đáp ứng được các mục đích và các yêu cầu đề ra.
Chương trình đã giải quyết tốt những yêu cầu đặt ra là quản lý được các khách hàng, các sản phẩm, qui trình xuất, nhập hàng hoá vật tư, quản lý công nợ khách hàng cũng như lập được các báo cáo quản trị cần thiết theo yêu cầu của người quản lý và nhà lãnh đạo.
Trong chương trình quản lý bán hàng này ngoài việc cập nhật các chứng từ phiếu nhập hàng, phiếu thu tiền công nợ khách hàng, viết hoá đơn bán hàng cho khách hàng,. một cách nhanh chóng, thuận tiện , chương trình còn đưa ra một hệ thống các báo cáo quản trị thích hợp. Các báo cáo này đã đáp ứng được hầu hết các yêu cầu của nhà quản lý, người lãnh đạo giúp họ có được những cái nhìn tổng quan về tình hình bán hàng và hoạt động sản xuất kinh doanh của doanh nghiệp mình. Từ đó giúp họ có thể đưa ra những chính sách chiến lược, những điều chỉnh kịp thời về tình hình sản xuất kinh doanh và hoạt động bán hàng của công ty.
Ngoài ra chương trình còn có chức năng ưu điểm nữa là các phiếu xuất và hoá đơn bán hàng có thể được xuất sang Microsoft Excel. Điều này giúp cho việc kiểm tra và tổng hợp số liệu một cách chính xác và đáp ứng các yêu cầu khi cần thiết.
138 trang |
Chia sẻ: aloso | Lượt xem: 1900 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Luận văn Phân tích và thiết kế hệ thống thông tin quản lý bán hàng tại công ty Gạch ốp lát Hà Nội, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
n trình “Xử lý bán hàng”(1.0):
1.1
Tiếp nhận đơn hàng
2.0
Xử lý thu tiền
1.3
Kiểm tra khách hàng
1.4
Kiểm tra hàng tồn
1.5
Giải quyết khách hàng
1.2
Kiểm tra đơn hàng
Khách hàng
Hồ sơ thẻ kho
Danh mục khách hàng
Đơn đặt
hàng
Từ chối
Đơn hàng
Thông tin phản hồi
Thông tin về khách hàng
Hoá đơn
Đơn hàng đã kiểm tra
1.6
Xử lý yêu cầu
Danh mục đơn đặt hàng
Hoá đơn
Đơn hàng đã kiểm tra
Hình 26: Sơ đồ DFD phân rã mức 1 ứng với tiến trình “Xử lý bán hàng”(1.0)
- Sơ đồ DFD phân rã mức 1 ứng với tiến trình “Xử lý thu tiền”(2.0)
2.1
Kiểm tra hoá đơn
2.2
Cập nhật vào sổ kế toán
4.0
Xử lý giao hàng (kho)
2.3
Chuyển hoá đơn bán hàng (phiếu xuất) sang bộ phận quản lý kho
Khách hàng
Hoá đơn
Hoá đơn đã kiểm tra
Phiếu thu
Thanh toán
Hoá đơn bán hàng
Khách hàng
Hàng hóa
Hình 27: Sơ đồ DFD phân rã mức 1 ứng với tiến trình “Xử lý thu tiền”(2.0)
- Sơ đồ luồng dữ liệu mức 0 của hoạt động nhập hàng:
2.0
Lập báo cáo về đơn đặt hàng
Phiếu nhập kho
1.0
Đặt hàng
5.0
Lập báo cáo xuát nhập tồn kho
4.0
Kế toán phải trả
6.0
Lập báo cáo tổng hợp chi
3.0
Tiếp nhận hàng
Bộ phận quản lý bán hàng
Nhà cung cấp
Lãnh đạo
Lãnh đạo
Sổ sách kế toán
Hồ sơ thẻ kho
Hồ sơ đơn hàng
Yêu cầu nhập hàng
Báo cáo đơn hàng
Báo cáo tồn kho
Đơn đặt hàng
Báo cáo tổng hợp chi
Phiếu giao hàng
Hoá đơn bán hàng
Phiếu chi
Hình 28: Sơ đồ luồng dữ liệu mức 0 của hoạt động nhập hàng hàng”(1.0)
- Sơ đồ DFD phân rã mức 1 ứng với tiến trình “Tiếp nhận hàng”(3.0)
3.1
Kiểm tra phiếu giao hàng
3.2
Kiểm tra hàng nhập
3.3
Xử lý nhập kho
Nhà cung cấp
Tệp phiếu nhập kho
Hồ sơ đơn hàng
Lãnh đạo
Phiếu giao hàng
đã kiểm tra
Danh sách hàng đạt yêu cầu
Phiếu nhập kho
Phiếu giao hàng
Phiếu nhập kho
Hình 29: Sơ đồ DFD phân rã mức 1 ứng với tiến trình “Tiếp nhận hàng”(3.0)
2.4. Từ điển dữ liệu (DD)
2.4.1. Phích xử lý lô gic
Phích Xử lý lô gíc hoạt động mua hàng:
- Phích Xử lý lô gíc “Đặt hàng”:
Tên xử lý: Đặt hàng
Tiến trình: 1.3
Mô tả tiến trình: Sau khi bộ phận quản lý kho báo cáo tình hình hàng hóa thì bộ phận mua hàng sẽ xem xét để tiến hành thủ tục mua hàng.
Luồng dữ liệu vào: Yêu cầu nhập hàng
Luồng dữ liệu ra: Thông tin về đơn đặt hàng
Kho dữ liệu: Hồ sơ đơn hàng
- Phích xử lý lô gíc “Kiểm tra phiếu giao hàng”:
Tên xử lý: Kiểm tra phiếu giao hàng
Tiến trình: 3.1
Mô tả tiến trình: Khi đơn đặt hàng gửi đến nhà cung cấp được chấp nhận thì họ tiến hành thủ tục giao hàng cho bộ phận mua hàng của công ty.
Luồng dữ liệu vào: Phiếu giao hàng từ nhà cung cấp
Luồng dữ liệu ra: Danh sách hàng đạt yêu cầu
Kho dữ liệu: Hồ sơ đơn hàng
- Phích xử lý lôgíc “Xử lý nhập kho”:
Tên xử lý: Xử lý nhập kho
Tiến trình: 3.3
Mô tả tiến trình: Bộ phận quản lý kho viết phiếu nhận hàng, tìm vị trí trong kho để đặt hàng.
Luồng dữ liệu vào: Danh sách hàng đạt yêu cầu
Luồng dữ liệu ra: Phiếu nhập kho
Kho dữ liệu: Tệp phiếu nhập kho
Phích Xử lý lô gíc hoạt động bán hàng:
- Phích xử lý lôgíc “Tiếp nhận đơn hàng”:
Tên xử lý: Tiếp nhận đơn hàng
Tiến trình: 1.1
Mô tả tiến trình: Bộ phận quản lý bán hàng tiếp nhận đơn đặt hàng của khách hàng
Luồng dữ liệu vào: Đơn đặt hàng của khách hàng
Luồng dữ liệu ra: Đơn đặt hàng của khách hàng đã được chấp nhận
- Phích xử lý lôgíc “Kiểm tra đơn đặt hàng”:
Tên xử lý: Kiểm tra đơn đặt hàng
Tiến trình: 1.2
Mô tả tiến trình: Sau khi đã tiếp nhận đơn đặt hàng của khách hàng, bộ phận bán hàng sẽ kiểm tra đơn đặt hàng, nếu chấp nhận thì tiếp tục xử lý, nếu không thì trả lời khách hàng.
Luồng dữ liệu vào: Đơn đặt hàng của khách hàng đã tiếp nhận
Luồng dữ liệu ra: Đơn đặt hàng của khách hàng đã kiểm tra
Kho dữ liệu: Danh mục đơn đặt hàng
- Phích xử lý lôgíc “Kiểm tra hàng tồn”:
Tên xử lý: Kiểm tra hàng tồn
Tiến trình: 1.4
Mô tả tiến trình: Sau khi đã kiểm tra đơn đặt hàng thì tiến hành kiểm tra hàng hóa để đáp ứng yêu cầu của khách hàng.
Luồng dữ liệu vào: Đơn hàng đã kiểm tra
Luồng dữ liệu ra: Hóa đơn bán hàng
Kho dữ liệu: Hồ sơ thẻ kho
- Phích xử lý lôgíc “Xử lý thu tiền”:
Tên xử lý: Xử lý thu tiền
Tiến trình: 2.0
Mô tả tiến trình: Sau khi đáp ứng yêu cầu của khách hàng thì bộ phận quản lý bán hàng sẽ tiến hành xử lý thu tiền, nếu là khách hàng quen nợ thì sẽ ghi vào sổ công nợ khách hàng phải thu, nếu khách hàng trả ngay thì viết hóa đơn thanh toán.
Luồng dữ liệu vào: Hóa đơn bán hàng
Luồng dữ liệu ra: Phiếu xuất kho
Kho dữ liệu: Sổ ghi công nợ khách hàng
2.4.2. Phích luồng dữ liệu
- Phích luồng dữ liệu xuất bán hàng hóa:
Tên luồng dữ liệu: Hóa đơn bán hàng
Mô tả: Số HĐ + Mã KH + Ngày bán + Diễn giải +
{ds hàng hóa}= Mã hàng + Số lượng yêu cầu + Số lượng đáp ứng
Vị trí luồng dữ liệu: Phân rã mức 1 tiến trình “ Bán hàng”
- Phích luồng dữ liệu xử lý thu tiền:
Tên luồng dữ liệu: Hóa đơn thanh toán
Mô tả: Số PT + Mã KH + Ngày thu + Nội dung +
{Chi tiết phiếu thu}= Số HĐ + Số tiền phải thu + Số tiền đã thu +
+ Số tiền còn phải thu
Vị trí luồng dữ liệu: Phân rã mức 1 tiến trình “Xử lý thu tiền”
- Phích luồng dữ liệu đặt mua hàng:
Tên luồng dữ liệu: Đơn đặt mua hàng
Mô tả: Số HĐ + Mã NCC + Ngày đặt + Nội dung +
{ds hàng đặt}= Mã hàng + Số lượng yêu cầu + Số lượng nhận được
Vị trí luồng dữ liệu: DFD mức 0 hoạt động mua hàng
2.4.3. Phích kho dữ liệu
- Phích kho dữ liệu phiếu nhập kho:
Tên kho dữ liệu: Tệp phiếu nhập kho
Mô tả: Phiếu nhập kho chứa các thông tin về hàng hóa được nhập vào kho trong một lần mua
Thông số: PNK = Số PN + Mã NCC + Ngày nhập + Kho + Nội dung +
{ds hàng nhập}= Mã hàng + Đơnvị tính + Số lượng + Đơn giá
Vị trí kho: phân rã mức 1 tiến trình “Tiếp nhận hàng”
- Phích kho dữ liệu phiếu xuất kho:
Tên kho dữ liệu: Hồ sơ đơn hàng
Mô tả: Phiếu xuất kho chứa các thông tin về hàng hóa được xuất bán cho khách hàng theo hóa đơn bán hàng
Thông số: PXK = Số PX + Mã KH + Ngày xuất + Nội dung + Mã kho +
{ds hàng xuất}= Mã hàng + Đơn vị tính + Số lượng + Đơn giá
Vị trí luồng dữ liệu: DFD mức 0 hoạt động bán hàng
- Phích kho dữ liệu xử lý thu tiền:
Tên kho dữ liệu: Sổ sách kế toán
Mô tả: Sổ sách kế toán chứa các thông tin về việc quản lý công nợ khách hàng theo hóa đơn thanh toán
Thông số: PT = Số PT + Mã KH + Ngày thu + Nội dung +
{Chi tiết PT}= Số HĐ+ Đơn vị tính + Số lượng + Đơn giá
Vị trí luồng dữ liệu: Phân rã mức 1 tiến trình “Xử lý thu tiền”
2.5. Sơ đồ phân rã chức năng chương trình dự kiến sẽ thực hiện
QUẢN LÝ HÀNG HOÁ
Quản lý danh mục
Thống kê và báo cáo
Quản lý hoá đơn
Trợ giúp
Hệ thống
Tìm kiếm
III. THIẾT KẾ CHƯƠNG TRÌNH
1. Thiết kế cơ sở dữ liệu
1.1. Thiết kế cơ sở dữ liệu logic đi từ các thông tin đầu ra
1.1.1. Các bước chi tiết khi thiết kế cơ sở dữ liệu từ các thông tin ra:
Bước 1: Xác định các đầu ra
Liệt kê toàn bộ các thông tin đầu ra.
Nội dung, khối lượng, tần suất và nơi nhận của chúng.
Bước 2: Xác định các tệp cần thiết cung cấp đủ dữ liệu cho việc tạo ra từng đầu ra.
Liệt kê các phần tử thông tin trên đầu ra:
Liệt kê các thuộc tính.
Đánh dấu các thuộc tính lặp ( ký hiệu- R ) - là những thuộc tính có thể nhận nhiều giá trị dữ liệu.
Đánh dấu các thuộc tính thứ sinh ( ký hiệu – S ) - là những thuộc tính được tính toán hoặc suy ra từ các thuộc tính khác.
Gạch chân các thuộc tính khoá cho các thông tin đầu ra.
Loại bỏ những thuộc tính thứ sinh khỏi danh sách, chỉ để lại các thuộc tính cơ sở.
Sau khi liệt kê các phần tử thông tin đầu ra sẽ tiến hành thực hiện việc chuẩn hoá mức 1 ( 1.NF ), mức 2 ( 2.NF ) và mức 3 ( 3.NF ). Các qui tắc chuẩn hoá dữ liệu đã được trình bày trong chương II (xem phần IV, mục 1.3).
Bước 3: Tích hợp các tệp để chỉ tạo ra một cơ sở dữ liệu
Bước 4: Xác định khối lượng dữ liệu cho từng tệp và toàn bộ sơ đồ
Bước 5: Xác định liên hệ lôgic giữa các tệp và thiết lập sơ đồ cấu trúc dữ liệu
1.1.2. Thiết kế cơ sở dữ liệu
Liệt kê các phần tử thông tin trên đầu ra:
Từ đầu ra “Hoá đơn bán hàng” ta lập được danh sách các thuộc tính:
Số hoá đơn
Diễn giải
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
Phương thức thanh toán
Số thứ tự (R)
Mã hàng (R)
Tên hàng (R)
Nơi sản xuất (R)
Ngày sản xuất (R)
Đơn vị tính (R)
Đơn giá (R)
Số lượng (R)
Thành tiền ((S), (R))
Cộng thành tiền (S)
Thuế VAT (S)
Tổng số tiền (S)
Tổng số tiền ghi bằng chữ (S)
Ngày lập hoá đơn
Người lập hóa đơn
Từ đầu ra “Phiếu nhập kho” ta lập được danh sách các thuộc tính:
Số xê-ri
Số phiếu nhập
Ngày nhập
Nhà cung cấp
Người giao hàng
Địa chỉ
Nội dung
Mã kho
Mã hàng (R)
Tên hàng (R)
Đơn vị tính (R)
Số lượng (R)
Đơn giá (R)
Thành tiền ((S), (R))
Tổng cộng (S)
Thủ kho
Kế toán trưởng
Thủ trưởng đơn vị
Từ đầu ra “Hoá đơn thanh toán” (Phiếu thu tiền) ta lập được danh sách các thuộc tính:
Số xê-ri
Số phiếu thu
Ngày
Khách hàng
Địa chỉ
Nội dung
Số hoá đơn
Số tiền
Tổng tiền (S)
Chú thích:
(R): ký hiệu các thuộc tính lặp.
(S): ký hiệu các thuộc tính thứ sinh.
Các thuộc tính gạch chân là các thuộc tính khoá.
Thực hiện việc chuẩn hoá dữ liệu
Danh sách thuộc tính
Chuẩn hoá 1.NF
Chuẩn hoá 2.NF
Chuẩn hoá 3.NF
Số hoá đơn
Diễn giải
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
Phương thức thanh toán
Số thứ tự (R)
Mã hàng (R)
Tên hàng (R)
Nơi sản xuất (R)
Ngày sản xuất (R)
Đơn vị tính (R)
Đơn giá (R)
Số lượng (R)
Thành tiền ((S), (R))
Cộng thành tiền (S)
Thuế VAT (S)
Tổng số tiền (S)
Ngày lập hoá đơn
Người lập hóa đơn
Số xê-ri
Số phiếu nhập
Ngày nhập
Nhà cung cấp
Người giao hàng
Địa chỉ
Nội dung
Mã kho
Mã hàng (R)
Tên hàng (R)
Đơn vị tính (R)
Số lượng (R)
Đơn giá (R)
Thành tiền ((S), (R))
Tổng cộng (S)
Thủ kho
Kế toán trưởng
Thủ trưởng đơn vị
Số xê-ri
Số phiếu thu
Ngày
Khách hàng
Địa chỉ
Nội dung
Số hoá đơn
Số tiền
Tổng tiền (S)
Hoá đơn bán hàng
Số hoá đơn
Diễn giải
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
Phương thức thanh toán
Ngày lập hoá đơn
Người lập hóa đơn
Chi tiết hoá đơn bán hàng
Số hoá đơn
Mã hàng
Tên hàng
Nơi sản xuất
Ngày sản xuất
Đơn vị tính
Đơn giá
Số lượng
Phiếu nhập
Số phiếu nhập
Ngày nhập
Nhà cung cấp
Người giao hàng
Địa chỉ
Nội dung
Thủ kho
Chi tiết phiếu nhập
Số phiếu nhập
Mã hàng
Tên hàng
Đơn vị tính
Số lượng
Đơn giá
Phiếu thu
Số phiếu thu
Số xê-ri
Ngày
Khách hàng
Địa chỉ
Nội dung
Số hoá đơn
Số tiền
Hoá đơn bán hàng
Số hoá đơn
Diễn giải
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
Phương thức thanh toán
Ngày lập hoá đơn
Người lập hóa đơn
Chi tiết hoá đơn bán hàng
Số hoá đơn
Mã hàng
Số lượng
Đơn giá
Hàng hoá
Mã hàng
Tên hàng
Nơi sản xuất
Ngày sản xuất
Đơn vị tính
Đơn giá
Phiếu nhập
Số phiếu nhập
Ngày nhập
Nhà cung cấp
Người giao hàng
Địa chỉ
Nội dung
Thủ kho
Chi tiết phiếu nhập
Số phiếu nhập
Mã hàng
Số lượng
Đơn giá
Hàng hoá
Mã hàng
Tên hàng
Đơn vị tính
Mã kho
Phiếu thu
Số phiếu thu
Số xê-ri
Ngày
Khách hàng
Địa chỉ
Nội dung
Số tiền
Hoá đơn bán hàng
Số hoá đơn
Mã khách hàng
Diễn giải
Phương thức thanh toán
Ngày lập hoá đơn
Người lập hóa đơn
Khách hàng
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
Chi tiết hoá đơn bán hàng
Số hoá đơn
Mã hàng
Số lượng
Đơn giá
Hàng hoá
Mã hàng
Tên hàng
Nơi sản xuất
Ngày sản xuất
Đơn vị tính
Nhà cung cấp
Mã ncc
Tên ncc
đại diện
Địa chỉ
Điện thoại
Phiếu nhập
Số phiếu nhập
Mã ncc
Ngày nhập
Nội dung
Chi tiết phiếu nhập
Số phiếu nhập
Mã hàng
Số lượng
Đơn giá
Hàng hoá
Mã hàng
Tên hàng
Đơn vị tính
Mã kho
Kho
Mã kho
Tên kho
Thủ kho
Khách hàng
Mã kh
Tên kh
Địa chỉ
Nợ đầu kỳ
Phiếu thu
Mã kh
Số phiếu thu
Số xê-ri
Ngày
Nội dung
Số tiền
Tích hợp các tệp để chỉ tạo ra một cơ sở dữ liệu
Sau khi tiến hành chuẩn hoá dữ liệu ta thấy có 2 tệp “Khách hàng”:
Khách hàng (từ đầu ra “Hoá đơn bán hàng”)
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
Khách hàng (từ đầu ra “Hoá đơn thanh toán”)
Mã kh
Tên kh
Địa chỉ
- Nợ đầu kỳ
Để được một tệp cơ sở dữ liệu đầy đủ, cần tích hợp 2 tệp trên với nhau thành một tệp duy nhất sau:
Khách hàng
Mã khách hàng
Tên khách hàng
Số tài khoản
Địa chỉ
Điện thoại
- Nợ đầu kỳ
Tương tự, từ 2 tệp “Hàng hoá” trên ta tích hợp thành 1 tệp duy nhất sau:
Hàng hoá
Mã hàng
Tên hàng
Nơi sản xuất
Ngày sản xuất
Đơn vị tính
Mã kho
1.2. Các bảng và mối quan hệ giữa các bảng trong cơ sở dữ liệu
1.2.1. Cấu trúc các bảng trong cơ sở dữ liệu
Khách hàng (dmkh)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
MaKH
Character
6
Mã khách hàng
TenKH
Character
30
Tên khách hàng
SoTK
Character
15
Số tài khoản
MaThue
Character
15
Mã số thuế
Diachi
Character
60
Địa chỉ
DienThoai
Character
10
Điện thoại
NoDauKy
Numeric
10
Nợ đầu kỳ
Hóa đơn bán hàng (hoadon)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
MaKH
Character
6
Mã khách hàng
SOHD
Character
6
Số hoá đơn
DienGiai
Memo
50
Diễn giải
ThanhToan
Character
30
Phương thức thanh toán
NgayHD
Date
8
Ngày lập hoá đơn
NguoiLapHD
Character
30
Người lập hoá đơn
Chi tiết hoá đơn bán hàng (cthoadon)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Mahang
Character
6
Mã hàng
SoHD
Character
6
Số hoá đơn
Soluong
Numeric
10
Số lượng
Dongia
Numeric
10
Đơn giá bán
Nhóm hàng (nhomhang)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Manhom
Character
6
Mã nhóm
Tennhom
Character
30
Tên nhóm
Hàng hóa (dmhang)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Mahang
Character
6
Mã hàng
TenHang
Character
30
Tên hàng
NoiSX
Character
40
Nơi sản xuất
NgaySX
Date
8
Ngày sản xuất
KichThuoc
Character
10
Kích thước
DVTinh
Character
10
Đơn vị tính
Nhà cung cấp (dmncc)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
MaNCC
Character
6
Mã nhà cung cấp
TenNCC
Character
30
Tên nhà cung cấp
Diachi
Character
60
Địa chỉ
DienThoai
Character
10
Điện thoại
Phiếu nhập (phieunhap)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Mancc
Character
6
Mã nhà cung cấp
Sopn
Character
6
Số phiếu nhập
DienGiai
Memo
50
Diễn giải
Ngaynhap
Date
8
Ngày nhập
Chi tiết phiếu nhập (ctphieunhap)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Mahang
Character
6
Mã hàng
Sopn
Character
6
Số hoá đơn
Soluong
Numeric
10
Số lượng
Dongia
Numeric
10
Đơn giá nhập
Makho
Character
6
Kho
Kho (dmkho)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Makho
Character
6
Mã kho
Tenkho
Character
30
Tên kho
Thủ kho
Character
25
Thủ kho
Tồn kho (tonkho)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
Makho
Character
6
Mã kho
Mahang
Character
6
Mã hàng
Sltondk
Numeric
10
Số lượng đầu kỳ
Phiếu thu tiền (phieuthu)
Tên trường
Kiểu dữ kiệu
Độ rộng
Mô tả
MaKH
Character
6
Mã khách hàng
Sopt
Character
6
Số phiếu thu
Ngaythu
Date
8
Ngày thu
Nội dung
Character
30
Nội dung thu
Sotien
Numeric
10
Số tiền
1.2.2. Mối quan hệ giữa các bảng trong cơ sở dữ liệu
2. Thiết kế giải thuật
Trong các bước mô tả và phân tích công việc ở trên, giúp chúng ta hình dung các công việc xử lý khi xây dựng các chức năng của chương trình. Tuy nhiên để thuận lợi cho các công việc thiết kế các bước xử lý cũng như viết các module, chúng ta nên xây dựng giải thuật xử lý các công việc chính, phức tạp để thuận lợi cho việc thực hiện chương trình. Chúng ta có thể mô tả xử lý bằng lưu đồ giải thuật vì lưu đồ mang tính trực quan và dễ kiểm tra giải thuật sai. Dưới đây mô tả các lưu đồ giải thuật chính của chương trình.
Các ký hiệu thường dùng trong thiết kế giải thuật
Ký hiệu xử lý
Ký hiệu điều kiện
Ký hiệu nhập/ Xuất thông tin
2.1. Thuật toán cập nhật phiếu nhập kho
Mở Form Phiếu nhập kho
Chọn thông tin về nhà cung cấp
Thi hành đoạn chương trình tự động tăng số phiếu
Chọn thông tin về hàng hóa
Lưu các thông tin vừa nhập
Cập nhật thông tin về nhà cung cấp
Cập nhật thông tin về hàng hóa
B
E
Tiếp tục?
Đóng form Phiếu nhập kho
Yes
Yes
Yes
No
No
No
Có thông tin về nhà cung cấp?
Có thông tin về hàng hoá?
Yes
Yes
No
2.2. Thuật toán tìm và sửa bản ghi
Dò tìm trong tệp CSDL
Chuẩn bị môi trường, mở tệp CSDL, sắp xếp theo khóa hay đặt lọc
Gán các giá trị ban đầu cho các biến
Nhập các thông tin cần tìm kiếm
Thông báo không tìm thấy
B
E
Tiếp tục?
Yes
Yes
No
No
Hiển thị nội dung cần sửa đổi
Có tìm thấy không?
Có sửa đổi không?
Đặt lại cấu hình, đóng tệp CSDL
Sửa bản ghi
Yes
No
2.3. Thuật toán tìm và sửa Hóa đơn bán hàng
B
Mở form Tìm kiém hóa đơn bán hàng
Nhập mã số hóa đơn cần tìm để sửa
Tìm kiếm trong CSDL
Đưa ra thông báo
Có tìm thấy không?
No
Yes
Xuất hiện form Hóa đơn bán hàng chứa các thông tin vừa nhập để tiến hành sửa
Lưu các thông tin vừa sửa
Yes
Tiếp tục?
No
Đóng form Tìm kiếm
E
2.4. Thuật toán lập báo cáo
Yes
Chọn loại báo cáo
Tìm và lọc theo yêu cầu
Báo cáo
Thông báo
B
E
Tiếp tục?
Đóng form Phiếu nhập kho
Yes
Yes
No
No
No
Nhập khoảng thời gian lập báo cáo
Kiểm tra
đúng?
Tim thấy?
3. Thiết kế giao diện xử lý
Thiết kế giao diện xử lý là xác định hệ thống thông tin trình bày thông tin như thế nào cho người sử dụng khi nhập dữ liệu vào hệ thống hoặc đưa kết quả ra.
3.1. Thiết kế vào
Mục đích của thiết kế vào là thiết kế các thủ tục nhập dữ liệu có hiệu quả và giảm thiểu các sai sót.
Một số nguyên tắc hữu ích cho việc thiết kế màn hình nhập liệu:
Khi nhập dữ liệu từ một tài liệu gốc, khuôn dạng màn hình phải giống như tài liệu gốc.
Nên nhóm các trường trên màn hình theo một trật tự có ý nghĩa, theo trật tự tự nhiên, theo tần số sử dụng, theo chức năng hoặc theo tầm quan trọng.
Không nhập các thông tin mà hệ thống thông tin có thể tìm được từ cơ sở dữ liệu hoặc tính toán được.
Đặt tên trường ở trên hoặc trước trường nhập.
Đặt các giá trị ngầm định cho phù hợp.
Sử dụng phím Tab để chuyển trường nhập.
Dựa theo các nguyên tắc trên ta tiến hành việc thiết kế màn hình nhập liệu của chương trình. Một số màn hình nhập liệu chính như sau:
3.2. Thiết kế ra
Một số nguyên tắc cơ bản cho việc trình bày thông tin ra màn hình:
Đặt mọi thông tin gắn liền với một nhiệm vụ trên cùng một màn hình. Người sử dụng không phải nhớ thông tin từ màn hình này sang màn hình khác.
Chỉ dẫn rõ ràng cách thoát khỏi màn hình. Đặt giữa các tiêu đề và xếp đặt thông tin theo trục trung tâm.
Nếu đầu ra gồm nhiều trang màn hình thì mỗi trang phải được đánh số thứ tự. Việc này giúp người sử dụng biết mình đang ở đâu.
Viết văn bản theo quy ước chung bằng cách sử dụng chữ in hoa, in thường, chữ gạch chân… và ngắt câu hợp lý.
Đặt tên đầu cột cho mỗi cột.
Tổ chức các phần tử của danh sách theo trật tự quen thuộc trong quản lý.
Cân trái các cột văn bản và cân phải các cột số. Đảm bảo vị trí dấu thập phân thẳng hàng.
Chỉ đặt màu cho những thông tin quan trọng.
Dựa trên những nguyên tắc này tiến hành thiết kế các báo biểu là các dạng chứa thông tin ra tiêu biểu:
Hóa đơn thanh toán: Hóa đơn thanh toán dưới dạng phiếu thu dùng để thanh toán công nợ khách hàng có mẫu sau:
Cty gạch ốp lát Hà Nội Số:……………
PHIẾU THU
Ngày…tháng…năm…….
Khách hàng:……………………………………………………………………..
Địa chỉ:…………………………………………………………………………..
Lý do thu:………………………………………………………………………..
Số tiền:…………………………………………………………………………..
Ghi bằng chữ:……………………………………………………………………
Khách hàng Kế toán trưởng Thủ trưởng đơn vị
Mẫu báo cáo tổng hợp hàng hóa:
BÁO CÁO TỔNG HỢP HÀNG HÓA
Kho:…………….
Từ ngày………….Đến ngày……….
Mã hàng
Tên hàng
Tồn đầu kỳ
Nhập trong kỳ
Xuất trong kỳ
Tồn cuối kỳ
SL
TG
SL
TG
SL
TG
SL
TG
Ngày….tháng…năm…..
Người lập biểu
Mẫu báo cáo công nợ chi tiết:
BÁO CÁO CÔNG NỢ CHI TIẾT
Từ ngày………..Đến ngày…………
Khách hàng:………………………………………………………………………
Ngày
Số CT
Nợ ĐK
Nợ trong kỳ
Trả trong kỳ
Nợ CK
Ngày….tháng…..năm……..
Người lập biểu
4. Kết quả thử nghiệm chương trình
Qua quá trình thử nghiệm, chương trình đã đạt được những kết quả quan trọng sau:
4.1. Quản lý được các danh mục
Danh mục hàng hóa
Danh mục nhóm hàng
Danh mục nhà cung cấp
Danh mục khách hàng
Danh mục kho
Nhân viên bán hàng
4.2. Quản lý hóa đơn
Cập nhật phiếu nhập hàng
Lập hóa đơn bán hàng
Lập hóa đơn thanh toán
4.3. Tìm kiếm
Tìm kiếm hàng hóa
Tìm kiếm khách hàng
Tìm kiếm nhà cung cấp
Tìm kiếm phiếu nhập hàng
Tìm kiếm hóa đơn bán hàng
4.4. Thống kê và báo cáo
Thống kê danh mục
Thống kê hàng nhập
Thống kê tình hình bán hàng
Tổng hợp hàng bán
Báo cáo xuất nhập tồn
Bảng kê hóa đơn bán hàng
Tổng hợp doanh số bán hàng
Báo cáo công nợ khách hàng
4.5. Sơ đồ phân rã chức năng của chương trình đã đạt được
Thống kê tình hình bán hàng
QUẢN LÝ BÁN HÀNG
Quản lý danh mục
Thống kê và báo cáo
Quản lý hoá đơn
Tìm kiếm
Đăng ký
người dùng
Khách hàng
Nhà cung cấp
Hàng hóa
Báo cáo công nợ khách hàng
Doanh số bán hàng
Bảng kê hóa đơn bán hàng
Báo cáo xuất nhập tồn
Tổng hợp hàng bán
Thống kê hàng nhập
Thống kê danh mục
Hóa đơn thanh toán
Hóa đơn bán hàng
Phiếu nhập
Khách hàng
Hàng hóa
Hóa đơn thanh toán
Hóa đơn bán hàng
Cập nhật hang tồn
Phiếu nhập
Kho
Nhân viên
Kết thúc
Bảng kê phiếu nhập
Bảng kê phiếu thu
Hệ thống
Trợ giúp
Hướng dẫn sử dụng
Giới thiệu chương trình
5. Một số giao diện màn hình chính
5.1. Màn hình giao diện chính của chương trình
5.2. Form Giới thiệu
5.3. Form danh mục khách hàng:
Form danh mục khách hàng chứa các Textbox giúp người sử dụng có thể nhập các thông tin về khách hàng theo các tên trường ở bên phải. Việc nhập liệu được tiện hành dễ dàng nhanh chóng vì có thể thao tác chỉ cần bằng bàn phím, dùng phím Tab để chuyển trường nhập.
Các nút chức năng:
Nút Thêm: Khi người sử dụng nhấn nút này thì màn hình cho phép nhập thêm các thông tin về khách hàng mới, sau khi thêm có thể tiến hành Lưu các thông tin vừa nhập hoặc Hủy bỏ chúng.
Nút Sửa: Khi muốn sửa các thông tin về một khách hàng nào đó thì nhấn nút Sửa, sau khi sửa có thể tiến hành Lưu các thông tin vừa sửa hoặc hủy bỏ các thông tin đó.
Nút Xóa: nút này cho phép xóa các thông tin hiện thời về khách hàng đang hiện trên màn hình.
Nút Tìm: người sử dụng có thể tìm kiếm các thông tin về hàng hóa nào đó khi nhấn nút này.
Nút Xem: Cho phép xem thông tin về tất cả các khách hàng hiện có.
Nút Thoát: cho phép người sử dụng thoát khỏi màn hình nhập liệu này.
Ngoài ra còn có các nút dịch chuyển bản ghi để dịch chuyển các bản ghi trong cơ sở dữ liệu.
5.4. Form Hoá đơn bán hàng:
Trên hoá đơn bán hàng các thông tin được thực hiện hầu như tự động, người sử dụng chỉ cần tiến hành giao tác vì các thông tin đã có sẵn trong cơ sở dữ liệu và chỉ việc nhập số lượng, đơn giá của mỗi loại hàng hóa bán (nếu không biết đơn giá bán là bao nhiêu thì có thể xem trong danh mục giá bán với đơn giá của ngày bán gần đây nhất).
Số phiếu tự động tăng lên sau mỗi lần xuất bán.
Ngày lập hoá đơn bán hàng mặc định là ngày hiện thời.
Người mua hàng được lấy từ Danh mục khách hàng, các thông tin về Mã Khách hàng, Tên Khách hàng, Địa chỉ được tự động cập nhật vào Hóa đơn bán hàng. Mã hàng lấy trong danh mục vật tư hàng hóa: các thông tin liên quan như Tên hàng, Đơn vị tính được tự động cập nhật vào Hóa đơn bán hàng.
Mã kho được lấy trong danh mục kho hàng.
Trên mỗi phiếu có thể nhập được nhiều mặt hàng ở nhiều kho khác nhau.
Sau mỗi lần nhập một mặt hàng trên phiếu phải thể hiện được trị giá của mặt hàng đó ở cột Thành tiền bằng cách lấy số lượng x đơn giá của mặt hàng đó.
Nút mới: bắt đầu thực hiện việc nhập mới một Hóa đơn bán hàng.
Nút Lưu: Thực hiện việc lưu phiếu.
Nút Sửa: Để sửa lại chứng từ cũ.
Nút Xóa: Để xóa chứng từ hiện thời.
Nút Tìm: Để tìm bất cứ chứng từ nào thỏa mãn điều kiện lọc.
Nút Thoát: Thoát khỏi màn hình nhập thông tin Hóa đơn bán hàng.
5.5. Form phiếu thu:
5.6. Form Tìm kiếm hàng hóa:
5.7. Form tìm kiếm hàng nhập:
5.8. Form gọi Báo cáo hóa đơn bán hàng:
- Bảng kê hóa đơn bán hàng:
- Bảng kê hóa đơn bán hàng đã xuất sang Excel:
5.9. Phiếu thu tiền bán hàng:
5.10. Form gọi báo cáo xuất nhập tồn:
- Báo cáo xuất nhập tồn:
Báo cáo Tổng hợp hàng bán:
5.12. Form gọi các báo cáo về tình hình bán hàng:
- Báo cáo khách hàng mua hàng nhiều nhất
6. Cài đặt và bảo trì hệ thống
3.1. Cài đặt hệ thống
Sử dụng các biện pháp cài đặt thông thường là:
- Cài đặt trực tiếp.
- Cài đặt song song.
- Cài đặt thí điểm.
- Cài đặt chuyển đổi theo giai đoạn.
Đào tạo hỗ trợ người sử dụng.
- Đào tạo người sử dụng hệ thống thông tin.
- Hỗ trợ người sử dụng hệ thống thông tin.
3.2. Bảo trì hệ thống
Đây là giai đoạn chiếm chi phí lớn nhất trong chu kỳ sống của một hệ thống.
Các kiểu bảo trì:
- Bảo trì hiệu chỉnh: Giải quyết lỗi thiết kế và lỗi lập trình còn tiềm ẩn trong hệ thống sau khi cài đặt.
- Bảo trì thích nghi: Sửa đổi hệ thống để phù hợp với các thay đổi của môi trường.
- Bảo trì hoàn thiện: Cải tiến hệ thống theo nhu cầu mới.
- Bảo trì phòng ngừa: Phòng ngừa các thay đổi trong tương lai.
Quản trị bảo trì hệ thống:
- Quản trị nhân sự trong hệ thống.
- Đo lường hiệu quả bảo trì hệ thống (Số lượng lỗi, khoảng thời gian giữa các lỗi, kiểu lỗi).
- Kiểm soát các yêu cầu bảo trì.
Thiết kế công việc, kế hoạch dự án
Yêu cầubảo trì, hệ thống hiện thời
Hệ thống hiện thời, đặc tả về yêu cầu thay đổi
Hệ thống mới, tài liệu, đào tạo và hỗ trợ
Thứ hạng ưu tiên, đặc tả về yêu cầu bảo trì phân công nhân sự
1.0
Quản trị các yêu cầu bảo trì
4.0
Triển khai các thay đổi
3.0
Thiết kế các thay đổi
2.0
Chuyển đổi các yêu cầu
Hồ sơ dự án
Tài liệu về hệ thống hiện tại, các yêu cầu BT
Các đặc tả về yêu cầu
Yêu cầu thay đổi
Các bước của quá trình bảo trì hệ thống
6.3. Đánh giá sau cài đặt
- Đánh giá dự án xem có đúng thời gian, tiến độ không.
- Đánh giá hệ thống: xem xét hệ thống có đạt mục tiêu đề ra không (Đánh giá sau một thời gian hoạt động).
- Báo cáo tổng kết dự án.
- Dự án hoàn thành đúng kế hoạch, đáp ứng nhu cầu kế hoạch.
KẾT LUẬN
Do đặc thù trong lĩnh vực sản xuất kinh doanh của công ty là sản xuất và kinh doanh các loại gạch men và gạch ốp lát, có nhiều loại hàng, nhóm hàng nên việc quản lý sản phẩm tại công ty có nhiều khó khăn. Qui trình sản xuất và kinh doanh của công ty cũng có những đặc thù riêng nên việc quản lý tiêu thụ sản phẩm của công ty được thực hiên hầu hết qua các kênh phân phối là các đại lý và các cửa hàng kinh doanh. Đề tài “phân tích và thiết kế hệ thống thông tin quản lý bán hàng tại công ty Gạch ốp lát Hà Nội” đã được khảo sát thực tế tại công ty Gạch ốp lát Hà Nội nên đã đáp ứng được các mục đích và các yêu cầu đề ra.
Chương trình đã giải quyết tốt những yêu cầu đặt ra là quản lý được các khách hàng, các sản phẩm, qui trình xuất, nhập hàng hoá vật tư, quản lý công nợ khách hàng…cũng như lập được các báo cáo quản trị cần thiết theo yêu cầu của người quản lý và nhà lãnh đạo.
Trong chương trình quản lý bán hàng này ngoài việc cập nhật các chứng từ phiếu nhập hàng, phiếu thu tiền công nợ khách hàng, viết hoá đơn bán hàng cho khách hàng,... một cách nhanh chóng, thuận tiện , chương trình còn đưa ra một hệ thống các báo cáo quản trị thích hợp. Các báo cáo này đã đáp ứng được hầu hết các yêu cầu của nhà quản lý, người lãnh đạo giúp họ có được những cái nhìn tổng quan về tình hình bán hàng và hoạt động sản xuất kinh doanh của doanh nghiệp mình. Từ đó giúp họ có thể đưa ra những chính sách chiến lược, những điều chỉnh kịp thời về tình hình sản xuất kinh doanh và hoạt động bán hàng của công ty.
Ngoài ra chương trình còn có chức năng ưu điểm nữa là các phiếu xuất và hoá đơn bán hàng có thể được xuất sang Microsoft Excel. Điều này giúp cho việc kiểm tra và tổng hợp số liệu một cách chính xác và đáp ứng các yêu cầu khi cần thiết.
Tuy vậy, đề tài cũng cần được hoàn thiện ở một số khía cạnh, đó là cùng với sự phát triển của Internet và thương mại điện tử, công ty đang có phương hướng triển khai việc đặt hàng, thanh toán và thực hiện các giao dịch thông qua Internet. Vấn đề này chưa được đề cập ở đây. Đó cũng chính là vấn đề cần được hoàn thiện để giải quyết và đáp ứng các yêu cầu đặt ra.
DANH MỤC TÀI LIỆU THAM KHẢO
Giáo trình Hệ thống thông tin quản lý, TS Trương Văn Tú – TS Trần Thị Song Minh, NXB Thống kê, Hà Nội, 2000.
Sử dụng và khai thác Microsoft Visual Foxpro 6.0, Nguyễn Ngọc Minh (Chủ biên), NXB Giáo dục, 2000.
Giáo trình Cơ sở dữ liệu SQL, Access, Trần Công Uẩn, NXB Thống kê, 2000.
Phân tích và thiết kế hệ thống thông tin, Nguyễn văn Ba, NXB Đại học Quốc Gia HN, 2003 .
Những bài thực hành Visual Foxpro, VN-Guide, NXB Thống kê, 2002.
6. Giáo trình Cấu trúc dữ liệu và giải thuật, PTS Hàn Viết Thuận, NXB Thống kê -Hà nội 1999.
7. Phân tích thiết kế hệ thống thông tin quản lý, ThS Đinh Thế Hiển, NXB Thống kê.
Phân tích thiết kế các hệ thống thông tin hiện đại, Nguyễn Văn Vỵ, NXB Thống kê, 2000.
Les systèmes d’infomation de gestion, James O’ Brien, De Borck Universitè.
PHỤ LỤC
Thủ tục Startup chương trình :
SET CENTURY ON
SET CLOCK STATUS
SET ESCAPE OFF
SET EXCLUSIVE OFF
SET EXACT OFF
SET DATE TO FRENCH
SET SAFETY
SET STATUS ON
SET HEADING OFF
SET REPROCESS TO -1
SET REFRESH TO 1, 1
SET SCOREBOARD OFF
SET MULTILOCKS ON
SET STATUS BAR ON
SET TALK OFF
SET HOURS TO 24
SET DELETED ON
CLEAR WINDOW
CLEAR ALL
ON ERROR
********************8
SET DEFAULT TO c:\chuongtrinh
set talk off
set safety off
set clock off
with _screen
.icon='c:\chuongtrinh\icon\a.ico'
.caption='Chuong trinh quan ly ban hang - Cong ty gach op lat Ha noi'
.controlbox=.F.
.closable=.F.
.maxbutton=.F.
.Minbutton=.F.
.Height=600
.Width=800
.Windowstate=2
endwith
Do ReleToolbar
DO FORM c:\chuongtrinh\scx\loginht.scx
DO FORM c:\chuongtrinh\scx\Startup.scx
DO c:\chuongtrinh\menu\mainmenu.mpr
SET PATH TO c:\chuongtrinh\scx
Read event
clear event
*****************************
Procedure ReleToolbar
If wexist([Database designer])
hide wind([Database designer])
endif
If wexist([report controls])
hide wind([report controls])
endif
If wexist([report designer])
hide wind([report designer])
endif
If wexist([form controls])
hide wind([form controls])
endif
If wexist([form designer])
hide wind([form designer])
endif
If wexist([color palette])
hide wind([color palette])
endif
If wexist([layout])
hide wind([layout])
endif
If wexist([query designer])
hide wind([query designer])
endif
If wexist([view designer])
hide wind([view designer])
endif
If wexist ([standard])
hide wind([standard])
endif
If wexist ([print preview])
hide wind([print preview])
endif
return
Thủ tục Them_Click của form Danh mục vật tư:
IF this.Parent.them.Caption ="\<Thêm" then
BEGIN TRANSACTION
this.Parent.them.Caption="\<Lưu"
this.Parent.sua.Caption="\<Hủy"
this.Parent.xoa.Enabled = .F.
this.Parent.dau.Enabled = .F.
this.Parent.truoc.Enabled = .F.
this.Parent.sau.Enabled = .F.
this.Parent.cuoi.Enabled = .F.
this.Parent.thoat.Enabled = .F.
this.Parent.xem.Enabled = .F.
thisform.txtdongia.ReadOnly = .f.
thisform.txtdongia2.ReadOnly = .f.
thisform.txtdvtinh.ReadOnly = .f.
thisform.txtmahang.ReadOnly = .f.
thisform.txttenhang.ReadOnly = .f.
thisform.txtngaysx.ReadOnly = .f.
thisform.txtnoisx.ReadOnly = .f.
APPEND BLANK
ELSE
this.Parent.them.Caption="\<Thêm"
this.Parent.sua.Caption="\<Sửa"
this.Parent.xoa.Enabled = .t.
this.Parent.dau.Enabled = .t.
this.Parent.truoc.Enabled = .t.
this.Parent.sau.Enabled = .t.
this.Parent.cuoi.Enabled = .t.
this.Parent.thoat.Enabled = .t.
this.Parent.xem.Enabled = .t.
thisform.txtdongia.ReadOnly = .t.
thisform.txtdongia2.ReadOnly = .t.
thisform.txtdvtinh.ReadOnly = .t.
thisform.txtmahang.ReadOnly = .t.
thisform.txttenhang.ReadOnly = .t.
thisform.txtngaysx.ReadOnly = .t.
thisform.txtnoisx.ReadOnly = .t.
END TRANSACTION
ENDIF
thisform.txtmahang.SetFocus
thisform.Refresh
Thủ tục Sua_click của form Danh mục vật tư:
IF this.Parent.sua.Caption ="\<Sửa" then
BEGIN TRANSACTION
this.Parent.them.Caption="\<Lưu"
this.Parent.sua.Caption="\<Hủy"
this.Parent.xoa.Enabled = .F.
this.Parent.dau.Enabled = .F.
this.Parent.truoc.Enabled = .F.
this.Parent.sau.Enabled = .F.
this.Parent.cuoi.Enabled = .F.
this.Parent.thoat.Enabled = .F.
this.Parent.xem.Enabled = .F.
thisform.txtdongia.ReadOnly = .f.
thisform.txtdongia2.ReadOnly = .f.
thisform.txtdvtinh.ReadOnly = .f.
thisform.txtmahang.ReadOnly = .f.
thisform.txttenhang.ReadOnly = .f.
thisform.txtngaysx.ReadOnly = .f.
thisform.txtnoisx.ReadOnly = .f.
ELSE
this.Parent.them.Caption="\<Thêm"
this.Parent.sua.Caption="\<Sửa"
this.Parent.xoa.Enabled = .t.
this.Parent.dau.Enabled = .t.
this.Parent.truoc.Enabled = .t.
this.Parent.sau.Enabled = .t.
this.Parent.cuoi.Enabled = .t.
this.Parent.thoat.Enabled = .t.
this.Parent.xem.Enabled = .t.
thisform.txtdongia.ReadOnly = .t.
thisform.txtdongia2.ReadOnly = .t.
thisform.txtdvtinh.ReadOnly = .t.
thisform.txtmahang.ReadOnly = .t.
thisform.txttenhang.ReadOnly = .t.
thisform.txtngaysx.ReadOnly = .t.
thisform.txtnoisx.ReadOnly = .t.
ROLLBACK
IF EOF()
SKIP -1
ELSE
SKIP 1
ENDIF
ENDIF
thisform.txtmahang.SetFocus
thisform.Refresh
Thủ tuc Xoa_click của form Danhmục vật tư:
SELECT dmh
IF MESSAGEBOX("Bạn muốn xoá bản ghi này chứ?",20,"Chu y!")=6
DELETE
CLOSE TABLES ALL
SELECT 1
SET EXCLUSIVE ON
USE dmh
PACK
IF !EOF()
SKIP
ENDIF
IF EOF() AND !BOF()
SKIP -1
ENDIF
ENDIF
thisform.Refresh
Thủ tục tiến lùi các bản ghi:
Dau_click:
SELECT dmh
IF NOT BOF()
GO top
this.Parent.dau.Enabled=.f.
this.Parent.truoc.Enabled=.f.
ELSE
=MESSAGEBOX("Đã đến bản ghi đầu rồi.",20,"Thong bao")=6 then
this.Parent.dau.Enabled=.f.
this.Parent.truoc.Enabled=.f.
ENDIF
this.Parent.sau.Enabled=.t.
this.Parent.cuoi.Enabled=.t.
thisform.Refresh
Truoc_click:
SELECT dmh
IF NOT BOF()
SKIP -1
ELSE
=MESSAGEBOX("Đã đến bản ghi đầu rồi.",20,"Thong bao")=6 then
this.Parent.dau.Enabled=.f.
this.Parent.truoc.Enabled=.f.
ENDIF
this.Parent.sau.Enabled=.t.
this.Parent.cuoi.Enabled=.t.
thisform.Refresh
Sau_click:
SELECT dmh
IF NOT EOF()
SKIP 1
ELSE
=MESSAGEBOX("Đã đến bản ghi cuối rồi.",20,"Thong bao")=6 then
this.Parent.sau.Enabled=.f.
this.Parent.cuoi.Enabled=.f.
ENDIF
this.Parent.dau.Enabled=.t.
this.Parent.truoc.Enabled=.t.
thisform.Refresh
Cuoi_click:
SELECT dmh
IF NOT EOF()
GO bottom
this.Parent.sau.Enabled=.f.
this.Parent.cuoi.Enabled=.f.
ELSE
=MESSAGEBOX("Đã đến bản ghi cuối rồi.",20,"Thong bao")=6 then
this.Parent.sau.Enabled=.f.
this.Parent.cuoi.Enabled=.f.
ENDIF
this.Parent.dau.Enabled=.t.
this.Parent.truoc.Enabled=.t.
thisform.Refresh
Thủ tục Moi_click của Form Hóa đơn bán hàng:
THISFORM.txtSopx.setfocus
THISFORM.txtSopx.gotfocus
THISFORM.txtNgaypx.value=""
THISFORM.txtmakh.value=""
thisform.lbltenkh.Caption=""
thisform.lbldiachi.Caption=""
THISFORM.txtdg.value=""
*+!+*********************************
THISFORM.cmgButton.cmdLuu.Enabled= .T.
THISFORM.cmgButton.cmdMoi.Enabled= .F.
THISFORM.cmgButton.cmdxoa.Enabled= .T.
THISFORM.cmgButton.cmdSua.Enabled= .T.
THISFORM.cmgButton.cmdtim.Enabled= .T.
THISFORM.TxtSopx.Enabled= .F.
THISFORM.TxtNgaypx.Enabled= .T.
THISFORM.Txtmakh.Enabled= .T.
THISFORM.TxtDG.Enabled= .T.
THISFORM.grdpx.colMahang.text1.value=""
THISFORM.grdpx.colTenhang.text1.value=""
THISFORM.grdpx.colDvt.text1.value=""
THISFORM.grdpx.colMakho.text1.value=""
THISFORM.grdpx.colSoluong.text1.value=""
THISFORM.grdpx.coldongia.text1.value=""
*+!+*********************************
* Them dong moi vao Grid
SELECT 1
APPEND BLANK
* Tu dong tang so phieu
SELECT 0
USE [C:\chuongtrinh\dbfs\hoadon.DBF] ALIAS M_hd
GO bottom
THISFORM.TxtSopx.Value=RECNO()+1
USE
THISFORM.Refresh
THISFORM.TxtNgaypx.SetFocus
thisform.grdpx.Refresh
Thủ tục Luu_click của Form Hóa đơn bán hàng:
* Cho phep cac nut
THISFORM.cmgButton.cmdLuu.Enabled= .F.
THISFORM.cmgButton.cmdMoi.Enabled= .T.
THISFORM.cmgButton.cmdxoa.Enabled= .F.
THISFORM.cmgButton.cmdSua.Enabled= .F.
THISFORM.cmgButton.cmdtim.Enabled= .T.
**********************************
* cap nhat vao bang : hoadon.DBF
SELECT 0
USE C:\chuongtrinh\dbfs\hoadon.DBF ALIAS M_hd
APPEND BLANK
SCATTER MEMVAR
M.Sohd=THISFORM.txtSopx.Value
M.Ngayhd=THISFORM.txtNgaypx.Value
M.makh=thisform.txtmakh.Value
M.Diengiai=THISFORM.TxtDg.Value
GATHER MEMVAR
RELEASE ALL
USE
* Cap nhap vao table : cthoadon.DBF
SELECT 3
USE C:\chuongtrinh\dbfs\cthoadon.DBF ALIAS cthoadon
SCATTER MEMVAR BLANK
M.Sohd=THISFORM.TxtSopx.Value
M.Mahang=THISFORM.Grdpx.ColMahang.Text1.Value
M.SoLuong=THISFORM.Grdpx.ColSoluong.Text1.Value
M.Makho=THISFORM.Grdpx.colMakho.Text1.Value
APPEND BLANK
GATHER MEMVAR
RELEASE ALL
USE
* Xoa tat ca cac bien
RELEASE ALL
thisform.Refresh
Thủ tục Sua_click của Form Hóa đơn bán hàng:
* Cho phep
THISFORM.cmgButton.cmdLuu.Enabled= .F.
THISFORM.cmgButton.cmdMoi.Enabled= .T.
THISFORM.cmgButton.cmdxoa.Enabled= .F.
THISFORM.cmgButton.cmdSua.Enabled= .F.
THISFORM.cmgButton.cmdTim.Enabled= .T.
***********************************
thisform.txtSopx.ReadOnly=.f.
thisform.txtNgaypx.ReadOnly=.f.
thisform.txtmakh.ReadOnly=.f.
thisform.txtdg.ReadOnly=.f.
thisform.grdpx.ReadOnly = .F.
thisform.grdpx.colMahang.text1.ReadOnly = .F.
thisform.txtSopx.Enabled = .T.
thisform.txtNgaypx.Enabled = .T.
thisform.txtmakh.Enabled = .T.
thisform.txtdg.Enabled = .T.
thisform.grdpx.colMahang.text1.Enabled = .T.
thisform.grdpx.colTenhang.text1.Enabled = .T.
thisform.grdpx.colDvt.text1.Enabled = .T.
thisform.grdpx.colMakho.text1.Enabled = .T.
thisform.grdpx.colSoluong.text1.Enabled = .T.
thisform.grdpx.coldongia.text1.Enabled = .T.
thisform.grdpx.colthanhtien.text1.Enabled = .T.
thisform.txtNgaypx.SetFocus
Thủ tục Lostfocus của TxtMaKh trên Form Hóa đơn bán hàng:
ON KEY LAbEl ENTER KEYBOARD CHR(23)
SELECT 0
USE C:\chuongtrinh\dbfs\dmkh.DBF ALIAS M_dmkh
IF EMPTY(THISFORM.Txtmakh.Value) THEN
BROWSE FONT '.VnArial',10 NOMODIFY
SCATTER MEMVAR
THISFORM.Txtmakh.Value=M.makh
THISFORM.Lbltenkh.Caption=ALLTRIM(M.tenkh)
thisform.lbldiachi.Caption =ALLTRIM(M.diachi)
RELEASE ALL
ENDIF
ON KEY LABEl ENTER
USE
***********************************
Thủ tục Lostfocus cua Text Mã hàng của grid trên Form Hóa đơn bán hàng:
on key label enter keyboard chr(23)
IF EMPTY(THISFORM.GRdpx.colMahang.text1.Value)=.T. THEN
SELECT 0
USE [c:\chuongtrinh\dbfs\dmh] ALIAS M_dmh
BROWSE FONT '.VnArial',10
SCATTER MEMVAR
strma=M.mahang
* Lay tu bang vao Grid
THISFORM.GRdpx.COlMahang.TExt1.Value=strma
THISFORM.Grdpx.ColTenhang.Text1.Value=M.TenHang
THISFORM.Grdpx.ColDvt.Text1.Value=M.Dvtinh
THISFORM.Grdpx.coldongia.Text1.Value=M.Dongia2
USE
ENDIF
on key label enter
Thủ tục Lostfocus cua Text Thành tiền trong Grid trên Form Hóa đơn bán hàng:
* Cho phep nguoi dung co them mat hang trong phieu nay nua khong
IF MESSAGEBOX('Bạn muốn nhập nữa không?',4,'Thong bao!')=6 THEN
SELECT 1
APPEND BLANK
RELEASE ALL
SELECT 0
USE C:\chuongtrinh\dbfs\cthoadon.DBF ALIAS P_ctpx
SCATTER MEMVAR BLANK
M.Sohd=THISFORM.TxtSopx.Value
M.Mahang=THISFORM.Grdpx.ColMahang.Text1.Value
M.SoLuong=THISFORM.Grdpx.ColSoluong.Text1.Value
M.Makho=THISFORM.Grdpx.colMakho.Text1.Value
APPEND BLANK
GATHER MEMVAR
RELEASE ALL
USE
THISFORM.Grdpx.ColMahang.Text1.SetFocus
THISFORM.Grdpx.Refresh
ELSE
thisform.cmgButton.cmdLuu.SetFocus
ENDIF
THISFORM.Refresh
Thủ tục tìm kiếm hóa đơn bán hàng, hiện thông tin trên Form Hóa đơn bán hàng, nếu tìm thấy có thể sửa:
* Thiet lap moi truong lam viec
SET TALK OFF
SET SAFETY OFF
SET EXAC OFF
SET DELETE OFF
SET DATE FRENCH
**********************************************
* Mở bảng con : cthoadon.dbf
SELECT 0
USE C:\Chuongtrinh\dbfs\cthoadon.DBF
INDEX ON sohd TO hd_sohd
USE C:\Chuongtrinh\dbfs\cthoadon.DBF INDEX hd_sohd ALIAS P_HangXuat
**********************************************
* Mở bảng cha : hoadon.DBF
SELECT 0
USE C:\Chuongtrinh\dbfs\hoadon.DBF
INDEX ON sohd TO pnk
USE C:\Chuongtrinh\dbfs\hoadon.DBF INDEX pnk ALIAS M_pnk
* Thiet lap moi quan he
SET RELATION TO sohd INTO P_HangXuat
SELECT P_HangXuat.sohd,P_HangXuat.MaHang,P_HangXuat.SoLuong,;
M_pnk.Ngayhd, M_pnk.DienGiai,M_pnk.makh,P_HangXuat.Makho;
FROM M_pnk,P_HangXuat;
WHERE P_HangXuat.sohd=M_pnk.sohd;
INTO DBF C:\chuongtrinh\dbf_tmp\Phieu_Hang
USE
**********************************************
* Mo ket qua chung va loc theo yeu cau ngay
SELECT 0
USE C:\Chuongtrinh\dbf_tmp\Phieu_Hang.DBF
SELECT *FROM Phieu_Hang;
WHERE (Phieu_Hang.Ngayhd BETWEEN CTOD(_dTu_Ngay) AND CTOD(_dDen_Ngay));
INTO DBF C:\Chuongtrinh\dbf_tmp\HD_Theo_Ngay
USE
**********************************************
* Ket qua Duoc loc Theo Ngay
SELECT 0
USE C:\Chuongtrinh\dbf_tmp\HD_Theo_Ngay
INDEX ON Mahang TO d_Mahang
USE C:\Chuongtrinh\dbf_tmp\HD_Theo_Ngay INDEX d_Mahang ALIAS P_TheoNgay
**********************************************
* Lay: fields cua mat hang tu: dmh.dbf
SELECT 0
USE C:\chuongtrinh\dbfs\dmh.dbf
INDEX ON Mahang TO dmh_Mahang
USE C:\chuongtrinh\dbfs\dmh.dbf INDEX dmh_Mahang ALIAS M_dmh
SET RELATION TO Mahang INTO P_TheoNgay
SELECT P_TheoNgay.sohd,P_TheoNgay.Ngayhd,P_TheoNgay.makh,;
P_TheoNgay.DienGiai, P_TheoNgay.Mahang,M_dmh.TenHang,;
M_dmh.dvtinh,P_TheoNgay.Makho, P_TheoNgay.SoLuong,M_dmh.dongia2,;
P_TheoNgay.SoLuong*M_dmh.dongia2 as thanhtien;
FROM M_dmh,P_TheoNgay;
WHERE P_TheoNgay.Mahang=M_dmh.Mahang;
INTO DBF C:\chuongtrinh\dbf_tmp\KQ_CUOI.dbf
USE
**********************************************
* Lay theo :SO phieu nhap
SELECT 0
USE C:\chuongtrinh\dbf_tmp\KQ_CUOI.dbf ALIAS H_CUOI
INDEX ON sohd TO kq_sohd
SELECT *FROM H_CUOI;
WHERE VAL(ALLTRIM(sohd)) BETWEEN VAL(_strTu_so) AND VAL(_strDen_So);
INTO DBF C:\chuongtrinh\dbf_tmp\PHIEU_XUAT.dbf
USE
**********************************************
* Loc theo ma nhan vien
SELECT 0
USE C:\chuongtrinh\dbf_tmp\PHIEU_XUAT.dbf ALIAS H_PNhap
SELECT *FROM H_PNhap;
WHERE makh=UPPER(ALLTRIM(_strMa_nv));
INTO DBF C:\chuongtrinh\dbf_tmp\HD_XUAT.dbf
* BROWSE
USE
**********************************************
SELECT 0
USE C:\chuongtrinh\dbf_tmp\HD_XUAT.dbf
USE
CLOSE ALL
Thủ tục đọc số thành chữ:
*......................... Hàm đổi số ............................
* Doi so thanh chu de in chung tu
FUNCTION Docso
PARAMETER So, DonViTinh, Doc_So_Bon
* SO: So can doi
* DonViTinh: Don vi tinh khi doc thanh chu (VND, USD,...)
* Doc_So_Bon: Doc so 4 la "bon" hay "tu" , neu = [T] - [tu], nguoc lai la [bon]
PRIVATE SoChu
IF PARAMETER() < 3
Doc_So_Bon = []
ENDIF
IF PARAMETER() < 2
DonViTinh = []
ENDIF
Tu_Bon = ' bốn'
IF UPPER(Doc_So_Bon) = 'T'
Tu_Bon = ' tư'
ENDIF
DIMENSION MangChuSo( 10 )
STOR [ không] TO MangChuSo(1)
STOR [ một] TO MangChuSo(2)
STOR [ hai] TO MangChuSo(3)
STOR [ ba] TO MangChuSo(4)
STOR [ bốn] TO MangChuSo(5)
STOR [ năm] TO MangChuSo(6)
STOR [ sáu] TO MangChuSo(7)
STOR [ bảy] TO MangChuSo(8)
STOR [ tám] TO MangChuSo(9)
STOR [ chín] TO MangChuSo(10)
SoChu = []
IF So < 0
So = - So
SoChu = SoChu + " âm"
ENDIF
So_sau_dau_phay = So - INT(So)
****Doc phan nguyen truoc
So = INT(So)
&&Vi ben duoi co doan S = LEFT(ALLT(S), LEN(ALLT(S)) - 1) ;
&& cho nen phai cho so 0 vao de neu doc so 0 thi no khong bi mat chu "g"
IF So = 0
SoChu = SoChu + " " + 'không0'
ELSE
&&Cong them cac so khong vao dang truoc chuoi de duoc chan cac to hop 3 so
So = ALLT(STR(So,16))
IF MOD(LEN(So) , 3 ) = 1
So = '00' + So
ENDIF
IF MOD(LEN (So), 3 ) = 2
So = '0' + So
ENDIF
So_Nhom = LEN(So)/3
Stt_Nhom = So_Nhom
Stt_So = 1
&&Doc theo tung nhom 3 so
DO WHILE Stt_So <= (LEN(So) - 2) &&Cho den vi tri cua chu so dau tien cua nhom cuoi cung
So_Phu = SUBSTR(So, Stt_So, 3)
Stt_Nhom = ROUND((LEN(So) - Stt_So +1) / 3, 0)
IF LEN(DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom)) > 0
IF Stt_Nhom < 5 &&Nho hon mot ty thi phai cng them dau phay
SoChu = SoChu + DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom) + [,]
ELSE
SoChu = SoChu + DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom)
ENDIF
ELSE
SoChu = SoChu + DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom)
ENDIF
Stt_So = Stt_So + 3
ENDDO
ENDIF
SoChu = LEFT(ALLT(SoChu), LEN(ALLT(SoChu)) - 1)
****Doc phan thap phan
* Neu chu so dau tien sau dau phay khac khong thi doc nhu phan so nguyen
IF So_sau_dau_phay > 0
SoChu = SoChu + " phẩy"
So_sau_dau_phay = ALLTR(STR(So_sau_dau_phay, 8, 6)) &&Chi doc den 6 chu so sau dau phay
So_sau_dau_phay = SUBS(So_sau_dau_phay, 3, LEN(So_sau_dau_phay) - 2) &&Cat lay phan sau dau phay
IF LEFT(So_sau_dau_phay, 1) '0'
&&Cat nhung so 0 o ben phai do STR() di
DO WHILE RIGHT(So_sau_dau_phay, 1) = '0'
So_sau_dau_phay = LEFT(So_sau_dau_phay, LEN(So_sau_dau_phay) - 1)
ENDDO
&&Cong them cac so khong vao dang truoc chuoi de duoc chan cac to hop 3 so
IF MOD(LEN(So_sau_dau_phay) , 3 ) = 1
So_sau_dau_phay = '00' + So_sau_dau_phay
ENDIF
IF MOD(LEN(So_sau_dau_phay), 3 ) = 2
So_sau_dau_phay = '0' + So_sau_dau_phay
ENDIF
So_Nhom = ROUND(LEN(So_sau_dau_phay) / 3,0)
Stt_Nhom = So_Nhom
Stt_So = 1
&&Doc theo tung nhom 3 so
DO WHILE Stt_So <= (LEN(So_sau_dau_phay) - 2)&&Cho den vi tri cua chu so dau tien cua nhom cuoi cung
So_Phu = SUBSTR(So_sau_dau_phay, Stt_So, 3)
Stt_Nhom = ROUND ((LEN (So_sau_dau_phay) - Stt_So +1) / 3,0)
SoChu = SoChu + DOI_SO_CHU_NHOM( So_Phu, Stt_Nhom, So_Nhom)
Stt_So = Stt_So + 3
ENDDO
ELSE
* Neu chu so dau tien sau dau phay = 0 thi doc tung chu so mot
&&Cat nhung so 0 o ben phai do STR() di
DO WHILE RIGHT(So_sau_dau_phay, 1) = '0'
So_sau_dau_phay = LEFT(So_sau_dau_phay, LEN(So_sau_dau_phay) - 1)
ENDDO
&&Doc lan luot tung chu so sau dau phay
FOR i =1 TO LEN(So_sau_dau_phay)
j = SUBS(So_sau_dau_phay, i, 1)
SoChu = SoChu + MangChuSo(VAL(j) +1 )
ENDFOR
ENDIF
ENDIF
SoChu = ALLTR(UPPER(LEFT(SoChu, 1)) + SUBS(SoChu, 2) + [ ] + DonViTinh)
RETURN SoChu
*......................... Function DOI_SO_CHU_NHOM ............................
FUNCTION DOI_SO_CHU_NHOM
PARAMETER Nhom_So, Stt_Nhom, So_Nhom
* Nhom_So: Nhom 3 so can doc
* Stt_Nhom: Stt cua nhom trong tong so cac nhom
* So_Nhom: Tong so nhom cua so can doc
PRIVATE Tram, Chuc, Don_Vi, Tram_Chu, Chuc_Chu, Don_Vi_Chu, Nhom_Chu
Nhom_Chu = ''
Tram = LEFT(Nhom_So,1)
Chuc = SUBSTR(Nhom_So,2,1)
Don_Vi = RIGHT(Nhom_So,1)
Tram_Chu = MangChuSo(VAL(Tram) +1 )
Chuc_Chu = MangChuSo(VAL(Chuc) +1 )
Don_Vi_Chu = MangChuSo(VAL(Don_Vi) +1 )
IF (Tram '0') .OR. ((Stt_Nhom = 1) .AND. (Stt_Nhom < So_Nhom))
Nhom_Chu = Nhom_Chu + Tram_Chu + ' trăm'
ENDIF
IF ALLTR(Chuc_Chu) 'không'
IF ALLTR(Chuc_Chu) 'một'
Nhom_Chu = Nhom_Chu + Chuc_Chu + ' mươi'
IF ALLTR(Don_Vi_Chu) 'năm'
IF ALLTR(Don_Vi_Chu) 'không'
IF ALLTR(Don_Vi_Chu) = 'một'
Nhom_Chu = Nhom_Chu + ' mốt'
ELSE
IF (ALLTR(Don_Vi_Chu) = 'bốn') .AND. (Stt_Nhom > 1)
Nhom_Chu = Nhom_Chu + Tu_Bon
ELSE
Nhom_Chu = Nhom_Chu + Don_Vi_Chu
ENDIF
ENDIF
ENDIF
ELSE
Nhom_Chu = Nhom_Chu + ' lăm'
ENDIF
ELSE
Nhom_Chu = Nhom_Chu + ' mười'
IF ALLTR(Don_Vi_Chu) 'năm'
IF ALLTR(Don_Vi_Chu) 'không'
Nhom_Chu = Nhom_Chu + Don_Vi_Chu
ENDIF
ELSE
Nhom_Chu = Nhom_Chu + ' lăm'
ENDIF
ENDIF
ELSE
IF ALLTR(Don_Vi_Chu) 'không'
Nhom_Chu = Nhom_Chu + ' linh'
IF ALLTR(Don_Vi_Chu) 'bốn'
Nhom_Chu = Nhom_Chu + Don_Vi_Chu
ELSE
Nhom_Chu = Nhom_Chu + Tu_Bon
ENDIF
ENDIF
ENDIF
IF (Tram = '0') .AND. (Chuc = '0') .AND. (Don_Vi '0') .AND. (Stt_Nhom > 1)
Nhom_Chu = Don_Vi_Chu
ENDIF
IF (Tram = '0') .AND. (Chuc = '0') .AND. (Don_Vi '0') .AND. (So_Nhom = 1)
Nhom_Chu = Don_Vi_Chu
ENDIF
DO CASE
CASE Stt_Nhom = 2
Nhom_Chu = Nhom_Chu + ' nghìn'
CASE Stt_Nhom = 3
Nhom_Chu = Nhom_Chu + ' triệu'
CASE Stt_Nhom = 4
Nhom_Chu = Nhom_Chu + ' tỷ'
CASE Stt_Nhom = 5
Nhom_Chu = Nhom_Chu + ' nghìn'
CASE Stt_Nhom = 6
Nhom_Chu = Nhom_Chu + ' triệu'
ENDCASE
IF (Tram = '0') .AND. (Chuc = '0') .AND. (Don_Vi = '0')
Nhom_Chu = ''
ENDIF
RETURN Nhom_Chu
Nguyễn Văn Tình – Lớp Tin học 42A – Khoa Tin học Kinh Tế - ĐH KTQD
Thời điểm
Khách hàng
Quản lý bán hàng
Quản lý kho
Kế toán thu
2.2.1. Sơ đồ IFD của bộ phận bán hàng
Luận văn tốt nghiệp đại học - 58 -
Lãnh đạo
Báo cáo
In báo cáo
Đơn đặt hàng
Xét duyệt đơn đặt hàng
Lưu trữ
Xử lý
Hoá đơn bán hàng
Giao dịch
Hợp đồng
Báo cáo
Báo cáo
Hoá đơn thanh toán
Phiếu xuất
Báo cáo xuất nhập tồn
Hình 19: Sơ đồ IFD của bộ phận bán hàng
Nguyễn Văn Tình – Lớp Tin học 42A – Khoa Tin học Kinh Tế - ĐH KTQD
Thời điểm
Nhà cung cấp
Quản lý mua hàng
Quản lý kho
Kế toán chi
2.2.2. Sơ đồ IFD của bộ phận mua hàng
Luận văn tốt nghiệp đại học - 59 -
Lãnh đạo
In báo cáo
Giới thiệu hàng
Sổ đơn hàng
Xử lý
Đơn đặt hàng
Báo cáo
Đặt hàng
Hợp đồng
Báo cáo
Báo cáo
Ra quyết định mua hàng
Hoá đơn thanh toán
Phiếu nhập kho
Báo cáo Xuất nhập tồn
Đơn đặt mua hàng
Quyết định mua hàng
Hình 20: Sơ đồ IFD của bộ phận mua hàng
Nguyễn Văn Tình – Lớp Tin học 42A – Khoa Tin học Kinh Tế - ĐH KTQD
Thời điểm
Quản lý mua hàng
Quản lý kho
Quản lý bán hàng
Kế toán
2.2.3. Sơ đồ IFD của bộ phận quản lý kho
Luận văn tốt nghiệp đại học - 60 -
Lãnh đạo
Lập báo cáo
Quyết định mua hàng
Kiểm duyệt và nhận hàng
Lưu trữ
Hoá đơn bán hàng
Báo cáo xuất nhập tồn
Mua hàng
Đơn đặt hàng
Phiếu nhập hàng
Bán hàng
Nguyễn Văn Tình – Lớp Tin học 42A – Khoa Tin học Kinh Tế - ĐH KTQD
Thời điểm
Hình 21: Sơ đồ IFD của bộ phận quản lý kho
Khách hàng
Quản lý bán hàng
Quản lý kho
Kế toán thu
2.3.4. Sơ đồ IFD của bộ phận thu tiền
Chuyên đề thực tập tốt nghiệp -61-
Lãnh đạo
Lập báo cáo thu
Phiếu thu
Sổ theo dõi công nợ
Xử lý
Báo cáo
Thanh toán
Phiếu thu
Hoá đơn bán hàng
Phiếu thu
Xử lý thu tiền
Hình 22: Sơ đồ IFD của bộ phận kế toán
Các file đính kèm theo tài liệu này:
- 36205.doc