Tài liệu Đề tài Xây dựng chương trình quản lý kho hàng trong hệ thông tin kế toán: LỜI NÓI ĐẦU
Trong 20 năm trở lại đây, một xu thế được thấy đặc biệt rõ nét ở các nước phát triển là số công việc liên quan đến tạo lập, xử lý thông tin ở dạng này hoặc dạng khác tăng lên nhanh chóng. Điều này khác hẳn so với những năm nửa đầu thế kỷ 20, khi công việc lao động chân tay chiếm vị trí chủ đạo.
Một trong những nguyên nhân chính của hiện tượng này là các ngành công nghiệp dịch vụ (như ngân hàng, khách sạn, du lịch, xuất bản...) tăng vọt. Đa số công việc thuộc lĩnh vực dịch vụ đều liên quan đến xử lý thông tin. Xử lý thông tin bằng máy được bắt đầu vào những năm 50, những thay đổi trong công nghệ xử lý thông tin diễn ra với nhịp độ rất nhanh kèm theo nhiều biến chuyển không dễ nhận thấy.
Để có thể thích ứng được với các biến chuyển trong đời sông kinh tế – xã hội, chúng ta cần nắm được thông tin. Đó là thông tin về những thay đổi có khả năng xẩy ra trong tương lai gần, là thông tin về các khả năng đương đầu có thể lựa chọn, thông tin về những người khác hành động như thế...
99 trang |
Chia sẻ: hunglv | Lượt xem: 970 | Lượt tải: 0
Bạn đang xem trước 20 trang mẫu tài liệu Đề tài Xây dựng chương trình quản lý kho hàng trong hệ thông tin kế toán, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
LỜI NÓI ĐẦU
Trong 20 năm trở lại đây, một xu thế được thấy đặc biệt rõ nét ở các nước phát triển là số công việc liên quan đến tạo lập, xử lý thông tin ở dạng này hoặc dạng khác tăng lên nhanh chóng. Điều này khác hẳn so với những năm nửa đầu thế kỷ 20, khi công việc lao động chân tay chiếm vị trí chủ đạo.
Một trong những nguyên nhân chính của hiện tượng này là các ngành công nghiệp dịch vụ (như ngân hàng, khách sạn, du lịch, xuất bản...) tăng vọt. Đa số công việc thuộc lĩnh vực dịch vụ đều liên quan đến xử lý thông tin. Xử lý thông tin bằng máy được bắt đầu vào những năm 50, những thay đổi trong công nghệ xử lý thông tin diễn ra với nhịp độ rất nhanh kèm theo nhiều biến chuyển không dễ nhận thấy.
Để có thể thích ứng được với các biến chuyển trong đời sông kinh tế – xã hội, chúng ta cần nắm được thông tin. Đó là thông tin về những thay đổi có khả năng xẩy ra trong tương lai gần, là thông tin về các khả năng đương đầu có thể lựa chọn, thông tin về những người khác hành động như thế nào trong các hoàn cảnh tương tự... Chính vì vậy, các tổ chức cần có trong tay một khối lượng lớn thông tin đủ mạnh để có thể nắm bắt được nhu cầu của khách hàng, nhìn thấy rõ xu thế cạnh tranh và môi trường kinh tế bên ngoài; đồng thời phải xử lý các thông tin này một cách nhanh nhất để có những quyết định kịp thời.
Như vậy, việc nắm bắt thông tin nhanh chóng, chính xác sẽ làm giảm bớt các yếu tố bất định cho cả tổ chức lẫn cá nhân. Thông tin đã trở thành một vấn đề sống còn đối với mọi lĩnh vực của đời sống kinh tế xã hội; đặc biệt là trong lĩnh vực quản lý kinh tế và nghiên cứu ứng dụng khoa học.
Qua quá trình thực tập tại Công ty TNHH dược , với sự giúp đỡ tận tình của thầy giáo hướng dẫn Đặng Quế Vinh, cùng với sự chỉ bảo của các anh chị đang làm việc tại công ty Fast em đã hoàn thành xong chuyên đề của mình với đề tài mang tên: Xây dựng chương trình quản lý kho hàng trong hệ thông tin kế toán.
Đề tài này được hình thành trên cơ sở nhu cầu cung cấp một cách đầy đủ, nhanh chóng, chính xác và thường xuyên có tính tác nghiệp cũng như tổng hợp những thông tin về tình hình số lượng cũng như chất lượng và hiện trạng của vật tư, hàng hoá trong kho và luân chuyển qua kho cho người lãnh đạo đơn vị để ra quyết định xuất nhập kho hữu hiệu nhất trong từng thời điểm nhất định.
Đề tài gồm các chương sau:
Chương I: Công ty Phần mềm tài chính kế toán Fast và bài toán quản lý kho hàng trong hệ thông tin kế toán. Chương này giới thiệu về công ty Fast nơi em thưc tập và nội dung bài toán "Xây dựng chương trình quản lý kho hàng trong hệ thông tin kế toán".
Chương II: Khảo sát thực tế. Chương này giới thiệu khái quát về vấn dề quản lý kho hàng đối với một doanh nghiệp, những thông tin đầu vào và đầu ra của bài toán.
Chương III: Phân tích và thiết kế hệ thống cho chương trình "Quản lý kho"
Em xin bày tỏ sự cám ơn sâu sắc của em tới Thầy giáo Đặng Quế Vinh đã tận tình hướng dẫn em hoàn thành chuyên đề này; cám ơn rất nhiều sự giúp đỡ từ phía các cán bộ, nhân viên Công ty Fast trong thời gian em thực tập tại đây.
Tuy nhiên, do thời gian có hạn và do vốn kiến thức của em còn hạn chế, thiếu kinh nghiệm thực tế nên chắc sẽ không tránh khỏi những thiếu sót. Vậy kính mong thầy giáo và tất cả những người quan tâm đến đề tài này thông cảm và bổ sung thiếu sót cho em.
Một lần nữa em xin chân thành cảm ơn !
CHƯƠNG I
CÔNG TY PHẦN MỀM TÀI CHÍNH KẾ TOÁN FAST
VÀ BÀI TOÁN QUẢN LÝ KHO HÀNG
Vài nét về lịch sử thành lập công ty
1. Quá trình thành lập công ty và lĩnh vực kinh doanh
Những năm đầu thập kỷ 90 này, chủ trương phát triển một nền kinh tế mở nhiều thành phần của Đảng và Nhà nước đã được toàn dân nhiệt liệt hưởng ứng và thực hiện. Nhiều doanh nghiệp của Nhà nước, tập thể và tư nhân đã ra đời và hoạt động trong nhiều lĩnh vực kinh tế xã hội khác nhau mang lại hiệu quả đáng kể cho nền kinh tế quốc dân.
Cũng trong thời gian này hoạt động công nghệ thông tin ở nước ta được quan tâm và phát triển mạnh mẽ theo tinh thần Nghị định 49CP của Chính phủ. Các cơ quan, đơn vị đều mở rộng việc áp dụng kỹ thuật tin học mới vào công tác quản lý không chỉ trong việc trang bị máy móc thiết bị hiện đại mà còn xây dựng và ứng dụng những phần mềm mới mạnh hơn, phù hợp hơn với yêu cầu của đơn vị, nhất là trong lĩnh vực hoạt động tài chính - kế toán. Đó chính là tiền đề cho ý tưởng thành lập Công ty cổ phần phần mềm tài chính kế toán Fast của các ông Nguyễn Thành Nam và Nguyễn Hồng Chương.
Thời gian chuẩn bị cho sự ra đời của Công ty Cổ phần Phần mềm Tài chính Kế toán được bắt đầu từ tháng 6 năm 1996 với sự đầu tư trí lực và tiền vốn của một nhóm cán bộ khoa học kỹ thuật tâm huyết với ngành tin học. Đến tháng 6 năm 1997 Công ty chính thức tuyên bố thành lập theo giấy phép số 3096/GP – UB do Uỷ ban nhân dân thành phố Hà Nội cấp ngày 11/6/1997 và giấy chứng nhận đăng ký kinh doanh số 056067 do Sở Kế hoạch và Đầu tư thành phố Hà Nội cấp ngày 18/6/1997.
Tên tiếng Việt của Công ty là: Công ty Cổ phần Phần mềm Tài chính Kế toán. Tên tiếng Anh của Công ty là: The Financial & Accounting Software Company, viết tắt là FAST.
Trụ sở công ty được đặt tại số 18 Đường Nguyễn Chí Thanh Quận Ba Đình Hà Nội.
Những ngày đầu Công ty Fast chỉ mới gồm 4 thành viên là các ông:
Phan Quốc Khánh: Giám đốc
Phan Đức Trung : Phó giám đốc
Phạm Văn Lộc : Trưởng phòng triển khai
Phạm Văn Nam : Bảo vệ
Là công ty cổ phần do các cổ đông góp vốn nên để đi vào hoạt động, Công ty đã bầu ra một hội đồng quản trị bao gồm các ông bà sau:
Bà Đinh Thị Hoa : Chủ tịch HĐQT
Ông Nguyễn Thành Nam: Phó chủ tịch HĐQT
Ông Phan Quốc Khánh: Phó chủ tịch HĐQT kiêm Giám đốc
Ônng Phan Đức Trung: Thành viên HĐQT
Ông Nguyễn Hồng Chương
Ông Nguyễn Khắc Thành
Ông Khúc Trung Kiên
Vốn điều lệ của công ty là 1.000.000.000đ chia thành 10.000 cổ phiếu, mỗi cổ phiếu trị giá 100.000đ.
Lĩnh vực kinh doanh chủ yếu của công ty được xác định từ ban đầu và được ghi trong giấy đăng ký kinh doanh là:
Sản xuất kinh doanh các phần mềm máy tính
Buôn bán hàng tư liệu tiêu dùng (thiết bị điện tử tin học, máy tính)
Dịch vụ thông tin khoa học và công nghệ
Dịch vụ tư vấn chuyển giao công nghệ.
2. Tổ chức và quy trình sản xuất kinh doanh của công ty Fast
2.1. Tổ chức của công ty Fast
Từ chỗ chỉ có 4 nhân viên ngày đầu thành lập, sau hơn 3 năm hoạt động Công ty đã có một độ ngũ nhân viên hơn 30 người với một chi nhánh ở TP Hồ Chí Minh.
Công ty Fast là một công ty cổ phần vì vậy lãnh đạo cao nhất của Công ty là Hội đồng quản trị, nơi đưa ra những quyết định quan trọng liên quan tới định hướng phát triển lâu dài của Công ty.
Bên dưới Hội đồng quản trị là Ban giám đốc Công ty – bộ phận trực tiếp điều hành hoạt động sản xuất kinh doanh hàng ngày theo kế hoạch của Công ty mà người đứng đầu là ông Phan Quốc Khánh - Giám đốc Công ty. Ban giám đốc Công ty là nơi đưa ra những quyết định kinh doanh cụ thể, trực tiếp.
Cơ cấu tổ chức của Công ty còn bao gồm các bộ phận như: nghiên cứu thị trường, sản xuất, kinh doanh, triển khai, kế toán, đào tạo, văn phòng và chi nhánh ở thành phố Hồ Chí Minh.
Bộ phận nghiên cứu thị trường có nhiệm vụ tìm kiếm thị trường, tìm kiếm khách hàng có nhu cầu về sản phẩm của Công ty mà ở đây chủ yéu là các sản phẩm phần mềm quản lý kế toán.
Bộ phận sản xuất có nhiệm vụ chủ yếu là viết các chương trình, các phần mềm theo những yêu cầu cụ thể của khách hàng; đồng thời phất triển phần mềm kế toán của riêng Công ty với mục đích để bán cho đông đảo những doanh nghiệp Việt Nam.
Bộ phận kinh doanh và triển khai có nhiệm vụ cài đặt, hướng dẫn khách hàng sử dụng những phần mềm của Công ty, bảo hành sản phẩm trong thời hạn thoả thuận, giải đáp những thắc mắc của khách hàng trong quá trình họ sử dụng và khai thác sản phẩm của Công ty.
Để phục vụ cho sự phát triẻn và mở rộng Công ty trong tương lai, Công ty Fast rất chú trọng tới việc đào tạo con người, với mục đích tạo dựng một đội ngũ nhân viên có đầy đủ khả năng, có thể đáp ứng được mọi đòi hỏi ngày càng khắt khe của khách hàng. Chính vì vậy, Công ty đã thành lập một bộ phận đào tạo (nội bộ) với mục đích bồi dưỡng liên tục về trình độ hiểu biết tin học cũng như nghiệp vụ kế toán cho mọi nhân viên trong Công ty.
Bộ phận Kế toán có chức năng nhiệm vụ là quản lý tài chính của Công ty, theo dõi thanh toán các hợp đồng, thanh toán các chi phí cho hoạt động sản xuất kinh doanh của Công ty, thực hiện chế độ hạch toán kế toán theo chế độ Nhà nước ban hành.
Bộ phận văn phòng có nhiệm vụ thực hiện công tác hành chính, quản trị và quan hệ của Công ty.
Chi nhánh của Công ty tại thành phố Hồ Chí Minh như một cánh tay nối dài và chịu mọi sự quản lý, chỉ đạo về hoạt động sản xuất kinh doanh của Công ty trên địa bàn các tỉnh, thành phố phía nam.
Xin được tóm tắt về cơ cấu tổ chức của Công ty Fast qua sơ đồ dưới đây:
Hội đồng quản trị
Ban giám đốc
Thị trường
Sản xuất
Kinh doanh
Triển khai
Kế toán
Đào tạo (nội bộ)
Văn phòng
Chi
nhánh tại Tp HCM
2.2. Quy trình hoạt động sản xuất kinh doanh
Công ty Fast là công ty cổ phần hoạt động kinh doanh với mục đích tìm kiếm lợi nhuận. Mặc dù sản phẩm của Công ty là các phần mềm tin học chủ yếu phục vụ cho các doanh nghiệp kinh doanh khác nhưng quy trình hoạt động sản xuất kinh doanh của Công ty cũng không có gì khác các doanh nghiệp này.
Trước tiên, Công ty phải nghiên cứu thị trường, tìm hiểu và xác định những yêu cầu của khách hàng trong lĩnh vực tài chính, kế toán của họ. Song song với việc này, Công ty tiến hành tiếp thị, giới thiệu cho khách hàng về chức năng hoạt động của Công ty, những khả năng mà Công ty có thể cung cấp, hỗ trợ cho khách hàng và những sản phẩm tin học của Công ty.
Khi đã có khách hàng, Công ty tiến hành sản xuất hàng hoá theo yêu cầu của khách. Ở đây, mảng công việc được đầu tư chính là viết các chương trình, các phần mềm tin học mà chủ yếu là các phần mềm kế toán và quản lý. Việc cung cấp tư liệu tiêu dùng (máy móc thiết bị) và các dịch vụ khác chỉ chiếm tỷ trọng nhỏ trong doanh số của Công ty .
Công ty Fast không chỉ viết các phần mềm theo yêu cầu của khách hàng mà còn luôn cố gắng thiết kế, xây dựng những phần mềm có thể phục vụ đông đảo các doanh nghiệp tại Việt Nam trên cơ sở đã nắm bắt được xu hướng và nhu cầu chung, trong đó, sản phẩm chính là chương trình kế toán Fast Accounting.
Với những sản phẩm riêng có này Công ty phải giới thiệu, quảng cáo, chào hàng rộng rãi tới các doanh nghiệp, các đơn vị để họ mua và sử dụng thường xuyên trong hoạt động tài chính kế toán của họ. Đây là một nhiệm vụ hết sức quan trọng và không thể thiếu được của Công ty Fast.
Tiếp theo việc bán hoặc cung cấp sản phẩm theo yêu cầu khách hàng là việc cài đặt hướng dẫn sử dụng các phần mềm này và bảo hành sản phẩm trong thời hạn thoả thuận. Điều này làm cho quan hệ giữa khách hàng và Công ty chặt chẽ hơn, tin cậy hơn; khách hàng sẽ làm việc lâu dài với Công ty.
Sau khi sản phẩm, hàng hoá đựợc bàn giao và nghiệm thu giữa hai bên việc thanh toán tiền hợp đồng mua bán hoặc cung cấp được bộ phận kế toán của Công ty thực hiện và quyết toán hợp đồng.
Quy trình hoạt động sản xuất kinh doanh của công ty Fast có thể được tóm tắt qua bảng sau:
Công việc, công đoạn
Bộ phận thực hiện
Nghiên cứu thị trường và tiếp thị
Thị trường (Marketing)
Sản xuất
Sản xuất (lập trình)
Bán hàng
Bán hàng
Triển khai và bảo hành
Triển khai
Thu tiền
Kế toán
II. Bài toán quản lý kho hàng trong hệ thông tin kế toán.
Fast là một công ty chuyên viết các phần mềm hỗ trợ các doanh nghiệp trong lĩnh vực quản lý tài chính kế toán. Phần mềm kế toán của Công ty đang được sử dụng rộng rãi trong nhiều doanh nghiệp hiện nay là phần mềm Fast Accounting. Đứng trước yêu cầu đòi hỏi ngày càng cao của khách hàng và sự thay đổi trong hệ thống kế toán Việt Nam, công ty Fast đã liên tục cho ra đời những phiên bản tiếp theo của phần mềm Fast Accounting.
Tuy nhiên, phần mềm Fast Acounting trước đây mới chỉ được viết trên ngôn ngữ lập trình Visual Foxpro. Để phục vụ cho những nhu cầu ngày càng đa dạng của khách hàng và cho mục tiêu phát triển lâu dài, Công ty Fast đang xây dựng phiên bản Fast Acounting mới trên cơ sở ngôn ngữ lập trình Visual Basic. Trong quá trình thực tập, với sự hướng dẫn của các anh chị trong Công ty em đã được giao công việc xây dựng bài toán quản lý kho hàng.
1. Giới thiệu về hệ thông tin kế toán
Hệ thống thông tin kế toán là hệ thống thông tin kinh doanh được sử dụng rộng rãi và rất lâu đời. Nó ghi chép và báo cáo các hoạt động kinh doanh và các hoạt động kinh tế khác. Hệ thống thông tin kế toán dựa vào việc lưu giữ sổ sách kế toán thông qua khái niệm bút toán kép tồn tại hàng trăm năm nay và các khái niệm kế toán khác hiện đại hơn như khái niệm trách nhiệm và khái niệm lợi tức. Hệ thống kế toán trên máy ghi chép và báo cáo các dòng vốn lưu chuyển qua doanh nghiệp dựa trên các số liệu phát sinh và đưa ra các bản báo cáo tài chính như bảng cân đối tài sản, báo cáo kết quả kinh doanh. Hệ thống này còn lập nên các dự đoán về tình hình tương lai như các báo cáo tài chính dự tính và dự toán ngân sách tài chính. Sau đó tình hình thực hiện tài chính thực tế được đem đối chiếu với các dự tính trên cơ sở các báo cáo kế toán phân tích khác nhau.
Hệ thông tin kế toán gồm có các phân hệ sau: Kế toán tổng hợp (sổ cái), Kế toán công nợ phải thu, Kế toán công nợ phải trả, Kế toán bán hàng, Kế toán mua hàng, Kế toán hàng tồn kho, Kế toán tiền lương, Kế toán tài sản cố định, Kế toán tập hợp chi phí và tính giá thành.
Các phân hệ nêu trên tuy là nằm trong hệ thông tin kế toán nhưng đều liên hệ chặt chẽ, trao đổi thông tin với các hệ thông tin quản lý khác trong doanh nghiệp. Phân hệ kế toán bán hàng liên kết với phân hệ quản lý đơn hàng trong hệ thông tin tiếp thị và kinh doanh; phân hệ kế toán hàng tồn kho liên kết với phân hệ quản lý hàng tồn kho trong hệ thông tin quản lý sản xuất; phân hệ kế toán tiền lương liên kết với hệ thông tin quản lý nhân sự,...
2. Bài toán quản lý kho hàng
Ứng dụng tin học vào công tác quản lý kế toán là nhằm mục đích hạn chế tối đa những sai sót, và tạo ra những sự giúp đỡ thuận tiện hơn đối với người làm công tác quản lý và kế toán. Quản lý kho hàng là một phần trong công tác quản lý, kế toán của một doanh nghiệp sản xuất kinh doanh. Chính vì vậy đã xuất hiện yêu cầu xây dựng Bài toán quản lý kho hàng. Thông qua khảo sát thực tế ở một số doanh nghiệp, ta có thể rút ra một số thông tin về bài toán như sau :
Đầu vào của bài toán: Bộ phận kế toán kho hàng nhận dữ liệu về nhập mua và xuất bán từ hai bộ phận mua hàng và bán hàng. Đối với các đơn vị sản xuất thì còn có thêm các phiếu xuất vật tư cho sản xuất. Các phiếu xuất sử dụng nội bộ, các phiếu điều chuyển kho và các điều chỉnh thừa thiếu khi kiểm kê cũng là các thông tin đầu vào của bài toán này.
Đầu ra của bài toán: Bộ phận kế toán kho hàng cần phải cung cấp các báo cáo về nhập, xuất, tồn kho, sổ chi tiết vật tư, các thẻ kho của từng vật tư ở từng kho, các báo cáo phân tích về mức độ luân chuyển của các mặt hàng, vật tư, báo cáo báo động về hàng thừa và hàng thiếu,...
Sự liên kết với các bộ phận khác: Bộ phận kế toán hàng tồn kho nhận số liệu từ các bộ phận mua và bán đồng thời chuyển số liệu sang bộ phận kế toán tổng hợp.
Từ các thông tin về đầu vào, đầu ra của bài toán quản lý kho cùng với mối liên hệ giữa bộ phận kế toán kho đối với các bộ phận khác trong doanh nghiệp ta có thể nêu ra những chức năng và mục đích của bài toán như sau:
2.1. Mục đích của đề tài
Xây dựng một chương trình cho phép thực hiện và quản lý một chu trình khép kín từ đầu đến kết thúc một quan hệ xuất nhập kho giữa một kho hàng của công ty với một khách hàng hay một kho hàng khác.
2.2. Chức năng của chương trình quản lý kho hàng
Theo dõi danh mục vật tư
Theo dõi tồn kho tức thời và tồn kho cuối kỳ
Tính giá vật tư tồn kho: giá trung bình, giá nhập trước, xuất trước hoặc giá đích danh
Theo dõi nhập, xuất và điều chuyển kho
Theo dõi mức tồn kho tối thiểu và tối đa
Theo dõi theo VNĐ và ngoại tệ.
2.3. Yêu cầu cập nhật chứng từ
Vào phiếu nhập vật tư, hàng hoá
Vào phiếu xuất và phiếu xuất điều chuyển vật tư, hàng hoá, công cụ lao động
In phiếu nhập, phiếu xuất trên máy
Liên kết số liệu với các phân hệ kế toán phải trả (nhập mua), kế toán phải thu (bán hàng) và giá thành (phân bổ tiêu hao nguyên vật liệu, công cụ lao động).
2.4. Báo cáo
Thẻ kho, sổ chi tiết hàng hoá, vật tư
Báo cáo nhập xuất tồn, Báo cáo tồn kho
Báo cáo vật tư, hàng hoá chậm luân chuyển
Báo cáo nhập, xuất (chi tiết và tổng hợp): theo ngày, theo nhà cung cấp, theo đơn vị sử dụng, theo dạng nhập xuất, theo vụ việc.
Ta có thể biểu diễn thông tin đầu vào và đầu ra của bài toán quản lý kho hàng thông qua sơ đồ sau :
III. Môi trưòng và công cụ
Ngôn ngữ
Chương trình được viết trên ngôn ngữ Visual Basic. Việc sử dụng Visual Basic for Windows đã áp dụng triệt để thành tựu của khoa học hiện đại nói chung và tin học hiện đại nói riêng, cụ thể là :
Visual Basic cho phép liên lạc giữa các phòng chức năng trở nên dễ dàng đáp ứng được nhu cầu thực tế về việc thực hiện giao dịch trực tiếp với khách hàng, đồng thời quản lý chặt chẽ các nhu cầu của các mặt hàng trên thị trưòng. Thông tin chuyển giao kịp thời, chính xác sẽ giúp cho cán bộ quản lí kho hàng và các cán bộ thuộc bộ phận bán hàng có những quyết định đúng đắn, và kiểm soát hàng hoá trong kho của mình được chính xác hơn do vậy sự thất thoát hàng hoá giảm và việc kinh doanh tiến triển tốt hơn.
Visual Basic là một hệ thống mở nên ta có thể sử dụng được nhiều cơ sở dữ liệu khác nhau như Foxpro (*.dbf), Microsoft Access (*.mdb), SQL server, Orcal, DBII,... do đó có thể phát triển chương trình cho việc sử dụng trên mạng diện rộng cho một Tổng Công Ty lớn hay một tập đoàn kinh tế ...
Visual Basic là ngôn ngữ bậc cao cung cấp cho người lập trình nhiều công cụ được sử dụng nhằm thiết kế chương trình sao cho có được một giao diện đẹp và thân thiện với người dùng.
Visual Basic là ngôn ngữ hướng đối tượng nên dễ lập trình, dễ bảo trì, dễ nâng cấp trong tương lai.
Các thuật ngữ được sử dụng trong ngôn ngữ Visual Basic:
Project: là sự liên kết của các Form, Module, Class, Aplicaltion, Custom contron để tạo thành chương trình.
Object: là các đối tượng mà ta có thể điều khiển chùng thông qua các thuộc tính của chúng. Ví dụ : Form, Data contron, Text box,...
Form: là màn hình giao diện mà người lập trình hoặc do Visaul Basic tạo ra trong khi thiết kế chương trình. MDIForm là form chính được tạo ra để làm nền chính cho chương trình mà qua đó ta điều khiển các Form con nhằm phục cho các mục đích cuả chương trình.Trên các Form nói chung chứa các đối tượng như Command button, Check button, Text box, Label...
Module: là tệp chứa các thủ tục xử lí .
Contron: là các đối tượng có thể điều khiển dùng trên Form nhằm lấy dữ liệu ví dụ Data contron..., hội thoại với người dùng Common dialog, Crytal repost...
Database: là một cơ sở dữ liệu thể hiện là một file. Ví dụ : (*.mdb) với Microsoft Access. Một Database có thể có nhiều bảng. Nói chung với một chương trình chỉ cần một Database để chứa dữ liệu. Khối lượng thông tin, dữ liệu có thể được chứa trong một Database là phụ thuộc vào tài nguyên của máy tính mà cụ thể là dung lượng bộ nhớ chứ không hạn chế số Table ( bảng ).
Table (bảng): là một phần của cơ sở dữ liệu nơi trực tiếp lưu trữ thông tin.
Cơ sở dữ liệu
Có ba loại dữ liệu chính mà Visual Basic có thể sử dụng được là:
Microsoft Access: là một hệ quản trị dữ liệu mà những tệp dữ liệu có thể được thao tác trực tiếp bởi Visual Basic. Đây là dạng dữ liệu chính của Visual Basic – Nó cung cấp rất nhiều khả năng và cho tốc độ truy nhập cao.
External Database. Những tệp dữ liệu loại này bao gồm những dạng dữ liệu như Btrieve, dBase III, dBase IV, Microsoft Foxpro Version 2.0 và 2.5 và Paradox. Ta có thể tạo hay thao tác tất cả các kiểu cơ sở dữ liệu trên bằng Visual Basic. Các tệp dạng ISAM của Visual Basic for MS-Dos không được hỗ trợ trực tiếp nhưng chúng có thể được chuyển thành dạng ASCII và sau đó chuyển lại thành dạng của Visual Basic.
External ODBC database: Loại này bao gồm các hệ quản trị cơ sở dữ liệu trên mạng client/server như Microsoft SQL server, DBII, Oracle... Trong trường hợp các tệp dữ liệu dạng ODBC, ta có thể gửi hoặc nhận những câu hỏi, câu trả lời thông qua việc gửi trực tiếp câu lệnh SQL tới Server.
Trong chương trình này, hệ cơ sở dữ liệu được xây dựng chủ yếu trong Microsoft Access vì đây là dạng dữ liệu được thao tác trực tiếp trên Visual Basic và có tốc độ truy nhập nhanh nhất.
Môi trường làm việc
Chương trình được thực hiện tốt trên các phiên bản Windows 9x, trong môi trường hệ điều hành mạng Novel Netware, Window NT,...
CHƯƠNG II
KHẢO SÁT THỰC TẾ
Qua khảo sát thực tế ở một số doanh nghiệp ta có thể tóm tắt lại quá trình lưu chuyển luồng thông tin trong doanh nghiệp như sau:
CỬA HÀNG
BANGIÁM ĐỐC
PHÒNG KẾ HOẠCH
PHÒNG KINH DOANH
Kho
PHÒNG TÀI VỤ
BANGIÁM ĐỐC
PHÒNG KẾ HOẠCH
PHÒNG KINH DOANH
Kho
PHÒNG TÀI VỤ
Luồng thông tin trong nhà máy
CỬA HÀNG
BANGIÁM ĐỐC
Kho
PHÒNG TÀI VỤ
PHÒNG KẾ HOẠCH
PHÒNG KINH DOANH
CƠ SỞ DỮ LIỆU
Luồng thông tin trong hệ thống tin học
I. Tóm tắt chức năng, nhiệm vụ, tổ chức và các quy trình nghiệp vụ của một công ty trong quản lý kho hàng
1. Chức năng, nhiệm vụ và tổ chức của công ty trong quản lý kho hàng
Mỗi một công ty có thể có nhiều địa điểm để cất trữ hàng hoá vật tư của mình. Các kho hàng này chịu sự quản lý trực tiếp từ trên công ty. Chức năng của các kho hàng là lưu giữ bảo quản các loại hàng hoá, vật tư của công ty, phân loại, sắp xếp hàng hoá vật tư theo chủng loại, thực hiện việc xuất nhập hàng hoá, vật tư theo các phiếu xuất nhập kho và phiếu lưu chuyển nội bộ, thực hiện việc thống kê, báo cáo về tình hình hàng tồn kho, tình hình xuất nhập hàng tại kho lên công ty kho.
Mối liên hệ giữa Ban giám đốc công ty và bộ phận quản lý kho có thể được mô tả theo sơ đồ dưới đây:
Công ty
Tổng kho
Kho 1
…
2. Mô tả thông tin và các quy trình nghiệp vụ
2.1. Mô tả thông tin
Tại mỗi kho hàng luôn có những thông tin đến và đi hết sức đa dạng về dạng, loại thông tin và cả về hình thức truyền tin. Sự đa dạng này phụ thuộc vào loại doạnh nghiệp, hình thức kinh doanh và vào cả loại hàng hoá, vật tư kinh doanh của doanh nghiệp.
Xét về các dạng thông tin ta thấy có thể là những file dữ liệu, cũng có thể là những văn bản báo cáo giấy tờ....
Xét về các loại thông tin đến và đi thì đó có thể là những văn bản, hoá đơn hay báo cáo...
Hình thức truyền tin có thể thông qua bưu điện, điện thoại, Fax, các đường truyền tin qua mạng hay con đường chuyển giao giấy tờ trong nội bộ công ty.
2.2. Các quy trình nghiệp vụ trong việc quản lý kho
Đối với mỗi kho hàng ta thấy những nghiệp vụ sau cần phải được thể hiện trong bài toán:
Nhận các hoá đơn bán hàng cho tất cả các đối tượng trong khu vực, vào sổ lưu.
Tính toán tiền thu, tiền thực thu, tiền nợ với từng khách hàng.
Theo dõi tình hình hàng hoá tồn của từng kho.
In ra các báo cáo hàng ngày, hàng tháng, hoặc bất kỳ (các mẫu báo cáo được xét đến ở phần sau).
II. Mô tả hệ thống thông tin điều hành và quản lý
1. Mục tiêu quản lý
Hệ thống thông tin điều hành và quản lý kho hàng được xây dựng với mục đích phục vụ và quản lý có hiệu quả quá trình điều hành công việc, xử lý, khai thác, trao đổi thông tin trong nội bộ công ty, giữa Ban giám đốc công ty với bộ phận quản lý kho và giữa các kho trong công ty ....
Các khâu xử lý bao gồm:
Tiếp nhận thông tin từ các bộ phận đưa vào bộ nhớ (hoá đơn, báo cáo, file dữ liệu....).
Xử lý công việc.
Theo dõi qúa trình bán hàng đối với từng khách hàng, quá trình thu tiền, theo dõi các khoản nợ, ....
Tổ chức lưu trữ thông tin
Cung cấp thông tin .
Khai thác thông tin (tìm kiếm, tra cứu....).
Tổng hợp thông tin, lập thống kê, báo cáo.
Trao đổi thông tin trong nội bộ.
2. Mô tả thông tin
Thông tin của hệ thống có thể chia làm 3 loại chính:
2.1. Thông tin danh mục
Các thông tin chung phục vụ việc quản lý, khai thác và theo dõi gọi là thông tin danh mục. Do nhu cầu phát triển và loại bỏ nên các danh mục này phải được thiết kế mở, có thể thay thế, sửa chữa, loại bỏ cũng như thêm vào.
Thông tin danh mục bao gồm:
Danh mục vật tư
Danh mục khách hàng
Danh mục các kho
Danh mục người sử dụng.
2.1.1. Danh mục các loại vật tư
Danh mục vật tư bao gồm tất cả các loại hàng hoá, vật tư có trong kho của công ty, gồm cả hàng hoá, vật tư công ty nhập vào cũng như xuất ra. Để phân biệt một cách chính xác giữa các loại hàng hoá, vật tư khác nhau, bên cạnh tên gọi mỗi một loại vật tư, hàng hoá sẽ được gán cho một mã gọi chung là mã vật tư.
MÃ VẬT TƯ
TÊN VẬT TƯ
01
02
03
A
B
C
2.1.2. Danh mục khách hàng
Danh mục khách hàng bao gồm tất cả các khách hàng có giao dịch với công ty, gồm cả khách hàng đến mua hàng hoá, vật tư của công ty cũng như đến bán hàng cho công ty. Để phân biệt một cách chính xác giữa các khách hàng khác nhau, bên cạnh tên gọi mỗi một khách hàng sẽ được gán cho một mã gọi chung là mã khách hàng. Ngoài ra mỗi khách hàng còn có những thông tin thêm như địa chỉ, số điện thoại.
MÃ KHÁCH HÀNG
TÊN KHÁCH HÀNG
TEL
ĐỊA CHỈ
AD-11001
AD-11002
AD-11003
AD-11006
AD-11008
Hanel shop
Hai yen
Dong an
Ha noi
ngmbv
8522246
8467345
8342790
8763459
8231678
91 Pho Hue
12 Ngo Quyen
23 Nguyen Du
167 Le Loi
98 Ly Nam De
2.1.3. Danh mục các kho
Danh mục kho bao gồm tất cả các kho hiện có của công ty. Để phân biệt một cách chính xác giữa các kho hàng khác nhau, bên cạnh tên gọi, mỗi một kho hàng sẽ được gán cho một mã gọi chung là mã kho. Ngoài ra mỗi kho hàng còn có thông tin thêm đó là địa chỉ hiện tại của kho.
MÃ KHO
TÊN KHO
ĐỊA CHỈ
HCM 01
HN 02
Daewoo-shop
Daewoo-Hanel
26/33 Van Don street, HCM city
98 Thanh Niên street, HN city
2.1.4. Danh mục người sử dụng
Danh mục người sử dụng bao gồm tất cả những người sử dụng hiện có đối với chương trình. Để phân biệt một cách chính xác giữa những người sử dụng chương trình khác nhau bên cạnh tên người sử dụng, mỗi một người sử dụng sẽ được gán cho một mã gọi chung là mã người sử dụng. Ngoài ra mỗi người sử dụng còn có thông tin thêm đó là mật khẩu và mức sử dụng. Mức sử dụng quy định cho mỗi người sử dụng chỉ được phép truy nhập, sử dụng chương trình tới một mức độ cho phép do người cấp quyền quy định. Mật khẩu giúp bảo đảm mỗi người sử dụng truy nhập chương trình đúng theo quyền của mình.
MÃ NGƯỜI SỬ DỤNG
TÊN NGƯỜI SỬ DỤNG
MỨC SỬ DỤNG
MẬT KHẨU
0001
0002
Thuc Anh
Phong Hai
1
2
***
***
2.2. Dữ liệu tác nghiệp.
Các nội dung thông tin cần quản lý như hoá đơn xuất kho, hoá đơn vận chuyển nội bộ, hợp đồng bán trả góp, phiếu bảo hành, tình trạng kho hàng,... được gọi chung là dữ liệu tác nghiệp.
Dữ liệu tác nghiệp là các nội dung thông tin cần đưa vào hệ thống trên cơ sở các nhu cầu về thông tin đầu ra và khả năng thu thập các dữ liệu đó.
Sau đây là mô tả đối với một số dữ liệu tác nghiệp: Hoá đơn xuất kho, hoá đơn nhập kho, hoá đơn vận chuyển nội bộ.
2.2.1. Hoá đơn xuất kho
Đơn vị : Mẫu số :03 – VT
QĐ số 1141 – TC/CĐKT
Ngày 1/1/1998 của Bộ Tài chính
PHIẾU XUẤT KHO
Ngày tháng năm
Số hiệu :
Số :
Nợ:
Có:
Họ tên người nhận hàng:
Xuất tại kho:
Lý do xuất kho:
STT
Tên, quy cách, sản phẩm
Mã SP
DVT
Số lượng
Đơn giá
Thành tiền
A
B
C
D
1
2
3
Cộng
Viết bằng chữ:
Xuất ngày tháng năm
Người nhận Thủ kho
2.2.2. Hoá đơn nhập kho
Đơn vị : Mẫu số :03 – VT
QĐ số 1141 – TC/CĐKT
Ngày 1/1/1998 của Bộ Tài chính
PHIẾU NHẬP KHO
Ngày tháng năm
Số hiệu :
Số :
Nợ:
Có:
Họ tên người giao hàng:
Nhập tại kho:
Diễn giải:
STT
Tên, quy cách, sản phẩm
Mã SP
DVT
Số lượng
Đơn giá
Thành tiền
A
B
C
D
1
2
3
Cộng
Viết bằng chữ:
Nhập ngày tháng năm
Người nhận Thủ kho
2.2.3. Hoá đơn vận chuyển nội bộ
Đơn vị : Mẫu số :03 – VT
QĐ số 1141 – TC/CĐKT
Ngày 1/1/1998 của Bộ Tài chính
PHIẾU LƯU CHUYỂN NỘI BỘ
Ngày tháng năm
Số hiệu :
Số :
Nợ:
Có:
Họ tên người giao hàng:
Xuất tại kho:
Nhập tại kho:
Diễn giải :
STT
Tên, quy cách, sản phẩm
Mã SP
DVT
Số lượng
A
B
C
D
1
Cộng
Ngày tháng năm
Người nhận Thủ kho
2.3. Thông tin kết xuất
Các báo cáo (Report) sau quá trình xử lý và tổng hợp thông tin được gọi là các thông tin kết xuất.
Thông tin kết xuất là kết quả của quá trình thu thập, xử lý các dữ liệu tác nghiệp. Thông tin kết xuất có thể hiểu là nhu cầu và đòi hỏi của các nhà quản lý đối với hệ thống.
2.3.1. Biểu báo tình hình xuất nhập kho
Công ty Fast BIỂU BÁO TÌNH HÌNH XUẤT NHẬP KHO
18 Nguyễn Chí Thanh Hà Nội Trong tháng : 01
Đơn vị tính : VND
Mã CT
Tên VT
Nhập
Xuất
Số Lượng
Đơn giá
Thành tiền
Số Lượng
Đơn giá
Thành tiền
01-01
Vinataba
10
6000
60000
01-01
555
20
13000
260000
01-02
Everest
10
6000
60000
01-02
Dulhill
50
10000
500000
01-01
Dulhill
40
12000
480000
01-01
555
15
20000
300000
01-01
Vinataba
10
7000
70000
Tổng nhập : 880000 Tổng xuất : 850000
Lợi tức : -30000
Ngày lập biểu : 29/02/2000
Người lập biểu
2.3.2. Biểu báo tình hình tồn kho
Công ty Fast
18 Nguyễn Chí Thanh Hà Nội
BIỂU BÁO TÌNH HÌNH HÀNG TỒN KHO
Mã kho
Tên kho
Tên vật tư
Số lượng
Đơn giá
Thành tiền
01
Kho1
Vinataba
10
6000
60000
01
Kho 1
555
20
13000
260000
01
Kho1
Everest
10
6000
60000
01
Kho1
Dulhill
50
10000
500000
02
Tổng kho
Dulhill
50
10000
500000
02
Tổng kho
555
20
13000
260000
02
Tổng kho
Vinataba
10
6000
60000
Ngày lập biểu : 29/02/2000
Người lập biểu
CHƯƠNG III
PHÂN TÍCH VÀ THIẾT KẾ HỆ THỐNG
Phân tích hệ thống
Phân tích hệ thống có cấu trúc là phương pháp tiếp cận hiện đại tới các giai đoạn phân tích và thiết kế của Chu trình phát triển hệ thống. Phương pháp này được chấp thuận để khắc phục những điểm yếu của nhiều cách tiếp cận truyền thống trước đây.
Mục đích của giai đoạn này là đưa ra phương pháp phân tích Lôgic về hệ thống hiện thời, từ đó rút ra các yêu cầu của nghiệp vụ quản lý kho hàng.
1. Sơ đồ luồng thông tin
Quá trình khảo sát về quản lý kho hàng trong một công ty đã tạo điều kiện thuận lợi để xây dựng sơ đồ trao đổi luồng thông tin tổng thể của quản lý kho hàng trong một công ty. Từ sơ đồ trao đổi thông tin này trở về sau trong quá trình phân tích thiết kế cơ sở dữ liệu, ta chỉ cần quan tâm đến các luồng thông tin chuyển đến và chuyển đi từ kho hàng. Sơ đồ này sẽ cho ta cái nhìn tổng quát về quá trình trao đổi thông tin nghiệp vụ giữa các qúa trình quản lý kho hàng của một công ty.
Sau đây sẽ là sơ đồ trao đổi thông tin nghiệp vụ quản lý kho
Từ các bộ phận
Kế toán vật tư
Lãnh đạo
Vật tư
Các bộ phận sản xuất
Bộ phân bán hàng
Chứng từ ban đầu
Phiếu nhập
Phiếu xuất
Báo cáo
Nhập
Xuất
Tồn
Sơ đồ luồng thông tin ICO
Quy trình trao đổi luồng thông tin nghiệp vụ quản lý kho được mô tả như sau:
Căn cứ vào tình hình xuất nhập hàng hoá, nguyên vật liệu của công ty các bộ phận sản xuất và bộ phận bán hàng sẽ ra quyết định xuất nhập vật tư, hàng hoá.
Khối lượng xuất nhập nguyên vật liệu được ghi trong các phiếu xuất nhập
Căn cứ vào khối lượng nguyên vật liệu xuất nhập sẽ tính toán lại lượng tồn trong các kho của công ty.
Xuất phát từ các phiếu xuất nhập kho và tình hình hàng hoá tồn kho sẽ tổng hợp thành những báo cáo gửi cho ban lãnh đạo công ty.
2. Sơ đồ luồng dữ liệu
Sơ đồ luồng dữ liệu DFD là một công cụ dùng để trợ giúp cho bốn hoạt động chính của nhà phân tích.
Phân tích DFD được dùng để giúp xác định yêu cầu của người sử dụng.
Thiết kế dùng để vạch kế hoạch và minh hoạ các phương án cho nhà phân tích và người dùng xem xét khi thiết kế hệ thống mới.
Liên kết - một trong những sức mạnh của DFD là tính đơn giản và dễ hiểu đối với nhà phân tích và người sử dụng.
Tài liệu: Việc dùng mô hình đồ thị như DFD trong đặc tả yêu cầu hình thức và thiết kế hệ thống là một nhân tố làm giản đơn hoá chính trong việc tạo ra và chấp nhận những tài liêu như vậy
Báo cáo
Quyết định
Ban lãnh đạo sản xuất kinh doanh
1.0
Xuất nhập NNVL, công cụ
2.0
Xuất nhập sản phẩm
3.0
Tính tồn
Lãnh đạo
Quyết định
3. Sơ đồ dòng dữ liệu phân rã mức 0 của hệ thông tin
4. Sơ đồ dòng dữ liệu phân rã mức 1 của hệ thông tin 5. Sơ đồ quan hệ giữa các thực thể
Có 3 kiểu quan hệ chính được sử dụng dưới các dạng đơn giản nhất của mô hình quan hệ. Đó là các loại ràng buộc một - một (1-1), một – nhiều (1-N), nhiều - nhiều (N-N).
Quá trình phân tích thiết kế dữ liệu đã dẫn đến việc hình thành một hệ thống các mối quan hệ giữa các tập tin với nhau. Hệ thống các mối quan hệ này có liên quan ràng buộc với nhau một cách chặt chẽ theo các nguyên tắc nhất định.
Dưới đây em xin trình bày hai sơ đồ quan hệ chính sau:
Sơ đồ quan hệ thực thể đối với phiếu Nhập kho:
DM_Kho
Ma_Kho *
Ten_Kho
Đia_chi
DM_Khach
Ma_Kh *
Ten_Kh
Đia_chi
DM_Vattu
Ma_vt *
Ten_vt
Soluong_min
Soluong_max
Dvi_tinh
Phieu_Nh
STT
Ma_ct *
Ngay
Ma_kh
Dien_giai
Ma_kho
TK_no
TK_co
Ct_Nhap
Ma_ct *
STT0 *
STT
Ma_vt
So_luong
Don_gia
Sơ đồ quan hệ thực thể đối với phiếu Xuất kho
DM_Kho
Ma_Kho *
Ten_Kho
Đia_chi
DM_Khach
Ma_Kh *
Ten_Kh
Đia_chi
DM_Vattu
Ma_vt *
Ten_vt
Soluong_min
Soluong_max
Dvi_tinh
Phieu_X
STT
Ma_ct *
Ngay
Ma_kh
Dien_giai
Ma_kho
TK_no
TK_co
Ct_Xuat
Ma_ct *
STT0 *
STT
Ma_vt
So_luong
Don_gia
II. Cấu trúc dữ liệu.
Tất cả các thực thể được lưu trữ trong file Hethong.mdb trong cùng thư mục chứa chương trình quản lý kho. Chúng ta có các thực thể sau:
Mật khẩu
Tên thực thể là MK, là nơi lưu trữ danh sách những người sử dụng chương trình với tên NSD, mức sử dụng, và mật khẩu của NSD.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
Ma
NSD
MK
MSD
ID
Autonumber
Char
Char
Longint
30
10
Trường khoá chính
Tên người sử dụng
Mật khẩu của NSD
Mức sử dụng
2. Danh mục kho
Tên thực thể là DmKho, là nơi lưu trữ danh mục các kho của công ty.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MaKho
TenKho
DiaChi
ID
Char
Char
Char
5
30
30
Trường khoá chính
Tên vật tư
Địa chỉ
3. Danh mục vật tư
Tên thực thể là DMVT, là nơi lưu trữ danh mục các hàng hoá vật tư có trong kho của công ty.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MaVT
TenVT
Dv_Tinh
Sl_min
Sl_max
ID
Char
Char
Char
Long_Integer Long_Integer
5
30
10
Trường khoá chính
Tên vật tư
Đơn vị tính
Số lưọng nhỏ nhất
Số lưọng lớn nhất
4. Danh nục khách
Tên thực thể là DMKH, là nơi lưu trữ danh mục các khách hàng có quan hệ xuất nhập hàng hoá, vật tư với công ty.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MaKh
TenKh
Tel
DiaChi
ID
Char
Char
Char
Char
5
30
11
50
Trường khoá chính
Tên khách hàng
Điện thoại của khách
Địa chỉ của khách
5. Phiếu nhập (Master)
Tên thực thể là PhieuNh, là nơi lưu trữ danh mục các phiếu nhập kho đối với các kho của công ty.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
Ma_CT
Ngay
TK_NO
TK_CO
MA_KH
MA_KHO
DIEN_GIAI
ID
Char
Date
Char
Char
Char
Char
Char
5
5
5
5
5
30
Trường khoá chính
Ngày chứng từ
Tài khoản nợ
Tài khoản có
Mã khách giao hàng
Mã kho nhập
Ghi chú
6. Chi tiết nhập (Details)
Tên thực thể là CtNh, là nơi lưu trữ danh mục các dòng của phiếu nhập kho có mã là Ma_Ct.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MA_CT
STT0
MA_VT
SO_LUONG
DON_GIA
ID
ID
Char
Number
Char
Number
Number
5
5
Mã chứng từ
Số thứ tự từng dòng
Mã vật tư
Số lượng
Đơn giá
1 many
Invoice(Master) Invoice(Details)
7. Phiếu lưu chuyển (Master).
Tên thực thể là PhieuLc, là nơi lưu trữ danh mục các phiếu nhập lưu chuyển của một kho đối với các kho khác của công ty.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
Ma_CT
Ngay
TK_NO
TK_CO
MA_KHO_N
MA_KHO_X
DIEN_GIAI
ID
Char
Date
Char
Char
Char
Char
Char
5
5
5
5
5
30
Trường khoá chính
Ngày chứng từ
Tài khoản nợ
Tài khoản có
Mã kho nhập
Mã kho xuất
Ghi chú
8. Chi tiết lưu chuyển (Details)
Tên thực thể là CtLc, là nơi lưu trữ danh mục các dòng của phiếu lưu chuyển có mã là Ma_Ct.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MA_CT
STT
MA_VT
SO_LUONG
ID
ID
Char
Number
Char
Number
5
5
Mã chứng từ
Số thứ tự từng dòng
Mã vật tư
Số lượng
1 many
Local voicher (Master) Local voicher (Details)
9. Phiếu xuất (Master)
Tên thực thể là PhieuX, là nơi lưu trữ danh mục các phiếu xuất kho đối với các kho của công ty.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
Ma_CT
Ngay
TK_NO
TK_CO
MA_KH
MA_KHO
DIEN_GIAI
ID
Char
Date
Char
Char
Char
Char
Char
5
5
5
5
5
30
Trường khoá chính
Ngày chứng từ
Tài khoản nợ
Tài khoản có
Mã khách nhận hàng
Mã kho xuất
Ghi chú
10. Chi tiết xuất (Details)
Tên thực thể là CtXuat, là nơi lưu trữ danh mục các dòng của phiếu xuất kho có mã là Ma_Ct.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MA_CT
STT0
MA_VT
SO_LUONG
DON_GIA
ID
ID
Char
Number
Char
Number
Number
5
5
Mã chứng từ
Số thứ tự từng dòng
Mã vật tư
Số lượng
Đơn giá
1 many
Invoice(Master) Invoice(Details)
11. Hàng tồn kho
Tên thực thể là TonKho, là nơi lưu trữ khối lượng hàng tồn kho đôí với từng mặt hàng và ở tựng kho.
THUỘC TÍNH
SỬ DỤNG
KIỂU
ĐỘ DÀI
GHI CHÚ
MaKho
MaVt
Ton_dq
ID
ID
Char
Char
Number
5
5
Mã kho
Mã vật tư
Lượng hàng tồn kho
III. Cấu trúc chương trình
Do cơ cấu tổ chức, thực tế công việc hiện nay của công ty nên sẽ chia toàn bộ hệ thống thành một số bài toán nhỏ nhưng vẫn cố gắng đảm bảo được tính nhất quán của cơ sở dữ liệu, tiện lợi cho việc hợp nhất thành một hệ thống hoàn chỉnh khi có điều kiện. Cấu trúc chương trình được thể hiện thông qua sơ đồ sau:
Quản lý kho hàng
Hệ thống danh mục
Giao dịch
Tìm kiếm và xử lý
Báo cáo
-DM Khách
-DM Kho
-DM Vật tư
-DM Chứng từ
-Phiếu nhập
-Phiếu xuất
-Phiếu lưu chuyển
-Tìm theo kho
-Tìm theo mã
-Tính hàng tồn
-Báo cáo tồn
-Báo cáo tổng hợp
-Thẻ kho
1. Phạm vi sủ dụng: Chương trình được sử dụng trong các kho hàng khu vực như: tổng kho, các kho con....
2. Dữ liệu vào: các hoá đơn xuất kho, phiếu bán hàng, phiếu vận chuyển nội bộ.
3. Thông tin kết xuất: Các báo cáo tình trạng xuất nhập của từng kho trong từng ngày, từng tháng, tình trạng kho hàng, bảng tổng hợp tình hình xuất nhập hàng gửi cho ban giám đốc công ty, các báo cáo trợ giúp quá trình phân tích kinh doanh.
4. Nhiệm vụ: Nhận các thông tin về sản phẩm có trong kho của mình (Transaction-Product file maintain).
Nhận các thông tin về kho (Transaction- Location Maintain).
Nhập vào máy các thông tin về hoá đơn bán hàng (Input/Output- Output voucher).
Nhập vào máy các hoá đơn vận chuyển nội bộ các mặt hàng chuyển từ kho khác đến, chuyển tới các kho khác (Input/Output .... Move local voucher).
Tổng kết tất cả các thông tin đưa vào bộ nhớ (Automatic).
Đưa ra các báo cáo theo mẫu, theo yêu cầu hỏi đáp (report).
CÔNG TY
Tổng kho
Kho 1
....
Kho 2
IV. Một số thuật toán trong chương trình
1. Thuật toán kiểm tra người sử dụng
false
True
True
False
Begin
-Nhập tên người sử dụng
-Nhập mật khẩu
Kiểm tra tên và MK
Hiện màn hình làm việc của chương trình
Có nhập lại không
Thoát khỏi chương trình
End
2. Thuật toán nhập phiếu nhập
True
false
True
false
Begin
Nhập ngày,mã chứng từ,Tk nợ có, diễn giải
Nhập mã kho
Kiểm tra mã kho trong bảng DM_kho
Hiện bảng DM_kho để chọn
Nhập mã khách
Lấy tên kho tương ứng điền vào hộp tên kho
Hiện bảng DM_kho để chọn
Lấy tên khách tương ứng điền vào hộp tên khách
Kiểm tra mã khách trong bảng DM_kh
false
True
false
True
Nhập mã vật tư
Kiểm tra mã vật tư trong bảng DM_vt
Hiện bảng DM_vt để chọn
Lấy tên vật tư tương ứng điền vào hộp tên vật tư
Nhập số lượng, đơn giá của vật tư
Tính tổng giá trị
Có nhập nữa không
Tính lại lượng tồn trong kho, lưu lại giá trị mới
Lưu phiếu nhập vào bảng phiếu nhập và bảng phiếu nhập chi tiết
Quay lại Menu chính
End
3.Thuật toán tính tồn cho phiếu xuất kho
False
True
True
False
BEGIN
Kiểm tra trong kho có mặt hàng đó không
Thông báo mặt hàng không có trong kho. Yêu cầu nhập lại
Kiểm tra trong kho mặt hàng đó có còn đủ gể xuất không
False
Thông báo mặt hàng không có đủ để xuất kho. Yêu cầu nhập lại
Cho xuất hàng trừ số lượng hành trong kho
END
Hàng tồn nhỏ hơn số lượng min
True
Thông báo lượng hàng trong kho nhỏ hơn số lượng min Yêu cầu nhập thêm
V. Xây dựng chương trình
1. Danh mục khách hàng
1.1. Chức năng
Phần này cho phép quản lý tất cả các khách hàng có quan hệ xuất nhập hàng hoá, vật tư đối với công ty. Nhân viên sử dụng chương trình nếu được quyền truy nhập vào chức năng này của chương trình sẽ đựợc phép thêm những khách hàng mới vào trong danh mục, sửa đổi thông tin về những khách hàng dã có sẵn trong danh mục khách hàng.
Do yêu cầu của công tác quản lý kho hàng, trong danh mục khách hàng chỉ lưu giữ những thông tin tối thiểu về mỗi khách hàng, đó là tên khách hàng, địa chỉ và số điện thoại của khách hàng.
Tất cả những khách hàng có tham gia vào một quy trình nghiệp vụ xuất hay nhập kho thì đều phải đưọc lưu giữ trong danh mục khách hàng. Khi xoá tên một khách hàng trong danh mục khách, tất cả những phiếu nhập xuất có tên khách hàng đó sẽ được chương trình tự động huỷ bỏ.
1.2. Giao diện Form danh mục khách hàng
Khi nhập một khách hàng mới cần phải nhập mã khách hàng. Mã này là duy nhất cho mỗi khách hàng nên chương trình phải kiểm tra sự trùng nhau giữa mã nhập vào và mã của những khách hàng đã có trong danh mục.
2. Danh mục vật tư
2.1. Chức năng
Phần này cho phép quản lý tất cả các vật tư, hàng hoá có trong mỗi kho của công ty. Nhân viên sử dụng chương trình nếu được quyền truy nhập vào chức năng này của chương trình sẽ đựợc phép thêm những tên hàng hoá, vật tư mới vào trong danh mục, sửa đổi thông tin về những vật tư, hàng hoá đã có sẵn trong danh mục vật tư.
Do yêu cầu của công tác quản lý kho hàng, trong danh mục vật tư chỉ lưu giữ những thông tin về hàng hoá, vật tư sau: tên vật tư, đơn vị tính, số lượng tối đa và số lượng tối thiểu vật tư đó được phép lưu giữ trong một kho hàng theo quy định của công ty. Những thông tin về từng loại vật tư được lưu giữ trong bảng DmVt trong file “Hethong.mdb”.
Tất cả những vật tư, hàng hoá xuất hiện trong một hoá đơn xuất hay nhập kho đều phải đưọc lưu giữ trong danh mục vật tư. Khi xoá tên một vật tư, tất cả những phiếu nhập, xuất có tên vật tư đó sẽ được chương trình tự động huỷ bỏ.
2.2. Giao diện Form danh mục vât tư
(xem ở trang sau)
Khi nhập một vật tư mới cần phải nhập mã vật tư. Mã này là duy nhất cho mỗi vật tư nên chương trình phải kiểm tra sự trùng nhau giữa mã nhập vào và mã của những vật tư đã có trong danh mục.
3. Màn hình phiếu Nhập kho
3.1. Chức năng
Phần này cho phép lưu giữ những phiếu nhập kho đối với tất cả các các kho của công ty. Nhân viên sử dụng chương trình khi vào màn hình nhập liệu, lựa chọn phiếu nhập kho sẽ được phép nhập thêm những phiếu nhập kho mới, xem lại những phiếu nhập kho đã nhập trước đó, xoá đi những phiếu nhập kho không còn cần phải lưu giữ. Để tạo điều kiện thuận lợi, nhanh chóng cho người sử dụng, trên màn hình nhập phiếu nhập có chức năng tìm kiếm phiếu nhập theo một số điều kiện cho trước như ngày nhập phiếu, mã phiếu...
Để tạo điều kiện thuận lợi, dễ dàng trong công việc, tạo cảm giác thân thiện đối với người sử dụng, màn hình nhập liệu Phiếu nhập kho được thiết kế gần giống với mẫu phiếu nhập kho theo quy định của bộ tài chính.
Thông tin về Phiếu nhập kho được lưu giữ trong hai bảng PhiêuNh và CtNh trong file “Hethong.mdb”. Tuy nhiên, để có được thông tin đầy đủ về một phiếu nhập kho, chương trình cần phải truy nhập vào các bảng DmVt, DmKh và DmKho. Quan hệ giữa các bảng được mô tả trong phần trước.
3.2. Giao diện Form Phiếu nhập kho
Khi nhập một phiếu nhập kho mới trước hết phải nhập mã chứng từ. Mã chứng từ là yếu tố giúp phân biệt giữa những Phiếu nhập kho với nhau, vì vậy không được phép có sự trùng nhau về mã chứng từ. Máy sẽ tự động kiểm tra, so sánh với những mã chứng từ đang lưu giữ, nếu có sự trùng lặp mã chứng từ thì sẽ thông báo và yêu cầu nhập lại mã chứng từ.
Đối với tên kho nhận hàng, tên khách giao hàng và vật tư, hàng hoá thì cần nhập mã số. Sau khi nhập mã số máy sẽ kiểm tra xem có mã đó trong danh mục tương ứng hay không. Nếu có mã đó thì sẽ cho hiện tên tương ứng, ngược lại nếu không tồn tại mã đó trong danh mục thì cho hiện danh mục với đầy đủ mã số và tên cho người nhập lựa chọn.
Với việc nhập vật tư hàng hóa, sau khi nhập xong một dòng máy sẽ tự động tính tổng giá trị khối lượng hàng đã nhập và tính lại lượng thuế giá trị gia tăng tương ứng.
Với công việc tìm kiếm những Phiếu nhập kho đã nhập trước đó, ta có thể dùng nút tua để tua lần lượt qua từng phiếu đến phiếu cần tìm hoặc nhấn nút tìm cho hiện Form tìm kiếm. Khi đã tìm được phiếu máy sẽ tự động hiển thị phiếu tìm được trên màn hình.
Khi lưu lại phiếu nhập kho chương trình sẽ ghi lại phần đầu phiếu vào bảng PhieuNh và ghi lại từng dòng trong phần bảng của phiếu cùng mã phiếu vào bảng CtNh. Sau đó chương trình sẽ thực hiện công việc tính lại hàng tồn kho.
Dưới đây là màn hình tìm kiếm:
4. Các báo cáo và phân tích tình hình xuất nhập tồn trong chương trình
Để phục vụ cho công tác quản lý kho hàng, đáp ứng yêu cầu nghiệp vụ quản lý kho, chương trình cho phép in ra những Phiếu nhập kho, Phiếu xuất kho và phiếu lưu chuyển nội bộ đang được lưu trữ trong máy.
Để phục vụ cho công tác báo cáo định kỳ về tình hình hàng hoá vật tư được lưu giữ trong kho, chương trình cho phép in ra những bảng báo cáo tình hình xuất nhập hàng hoá của các kho theo ngày, theo tháng hoặc theo năm.
Chương trình còn cho phép in ra bảng báo cáo tình hình hàng tồn kho tại các kho của công ty.
Như chúng ta đã biết, hàng hoá xuất kho với khối lượng lớn là một trong những yếu tố chứng tỏ loại hàng đó đang có nhu cầu lớn trên thị trường. Để trợ giúp cho việc phân tích kinh doanh của công ty, chương trình cho phép in ra bảng báo cáo tình hình xuất kho của hàng hoá xuất kho theo thứ tự khối lượng xuất kho.
Để phục vụ cho công tác tra cứu những thông tin về một loại hàng tồn kho được nhanh chóng thuận tiện, chương trình cho phép in ra báo cáo về tình trạng tồn kho (bao gồm khối lượng tồn kho và địa điểm kho đang cất giữ) của một loại hàng hoá, vật tư theo yêu cầu của người sử dụng.
Dưới đây là một số màn hình báo cáo của chương trình
Màn hình báo cáo tình hình hàng tồn kho
Màn hình báo cáo tình hình nhập xuất trong tháng
5. Màn hình chính của chương trình quản lý kho
Màn hình chính của chương trình quản lý kho được thiết kế với một hệ thống Menu, menu popup, các Toolbar và Taskbar giúp cho người sử dụng có cảm giác thoải mái, thuận tiện trong khi sử dụng.
6. Sơ đồ quan hệ thực thể
Cơ sở dữ liệu của chương trình như đã trình bày ở trên được xây dựng trên hệ quản trị cơ sở dữ liệu Access. Màn hình quan hệ giữa các thực thể của Access là một công cụ hết sức hữu ích và tiện lợi. Qua đây ta có thể có đựoc một cái nhìn đầy đủ, rõ ràng về mối quan hệ giữa các thực thể trong cơ sở dữ liệu với nhau.
KẾT LUẬN
Trong quản lý kinh doanh, tin học ngày càng đóng vai trò quan trọng. Nó đang trở thành một bộ phận cấu thành của hệ thống công cụ quản lý kinh tế, tài chính, có vai trò tích cực trong quản lý điều hành và kiểm soát các hoạt động kinh tế của Nhà nước cũng như các hoạt động kinh tế tài chính của doanh nghiệp.
Môi trường kinh tế mới kết hợp với sự đầu tư nước ngoài ngày càng mở rộng cùng với việc tự chủ trong hạch toán kinh doanh buộc các doanh nghiệp phải tổ chức tốt các hoạt động kinh doanh của mình, nắm bắt được tình hình kết quả kinh doanh của đơn vị để đảm bảo lợi nhuận thu được là cao nhất.
Việc sử dụng các chương trình tin học trong quản lý sẽ giúp các đơn vị giảm bớt được các nguồn chi phí, gián tiếp làm giảm giá thành sản phẩm, nâng cao được tính cạnh tranh của mình trên thị trường.
Chương trình Fast Acounting được thiết kế và xây dựng đã đáp ứng được mong muốn đó của các doanh nghiệp. Chính vì vậy Fast Acounting đã được đông đảo những doanh nghiệp đặc biệt là những doanh nghiệp vừa và nhỏ sử dụng trong hoạt động kinh doanh.
Xây dựng bài toán quản lý kho hàng trong hệ thông tin kế toán tuy chỉ là một phần của cả một bài toán kế toán quản lý doanh nghiệp nhưng em cũng đã cố gắng xây dựng chương trình nhằm đạt được mục đích, đem lại những thuận lợi cho người khai thác, sử dụng. Việc sử dụng chương trình không đòi hỏi người sử dụng phải có những hiểu biết sâu về tin học hay công nghệ thông tin. Hệ thống giao diện thực đơn, cửa sổ, hộp thoại, phím tắt của chương trình mang tính đơn giản, tiện dụng và thân thiện với người sử dụng.
Chương trình này được thiết kế theo hướng các nhà thiết kế có thể sửa đổi thêm bớt các thuộc tính chức năng của chương trình khi cần thiết. Nó cũng được thiết kế theo hướng mở để tạo thuận lợi hơn cho người sử dụng.
Tuy nhiên, chương trình còn tồn tại một số nhược điểm như tốc độ xử lý sẽ giảm nếu dữ liệu vào lớn, hình thức báo cáo in ra chưa được đẹp ...
Dẫu vậy, chương trình vẫn là một sản phẩm có một giá trị thực tiễn cao và thực sự đem lại nhiều tiện lợi cho người sử dụng.
PHỤ LỤC CHƯƠNG TRÌNH
I. Form DMKH
Dim kt As Boolean
Private Sub Command1_Click()
If Command1.Caption = "Nhập" Then
frame1.Enabled = True
Command2.Enabled = True
Command3.Enabled = False
Command1.Caption = "Lưu"
Command2.Caption = "Hoãn"
Text1.SetFocus
Else
Data1.Recordset.AddNew
Data1.Recordset.Fields(0).Value = Text1.Text
Data1.Recordset.Fields(1).Value = Text2.Text
Data1.Recordset.Fields(2).Value = Text3.Text
Data1.Recordset.Update
Data1.Refresh
frame1.Enabled = False
Command2.Enabled = True
Command3.Enabled = True
Command1.Caption = "Nhập"
Command2.Caption = "Xoá"
End If
End Sub
Private Sub Command2_Click()
If Command2.Caption = "Xoá" Then
dk = MsgBox("Bạn có chắc chắn xoá không ?", vbYesNo + vbQuestion, "Chú ý")
If dk = vbYes Then
Data1.Recordset.Delete
Data1.Refresh
If Data1.Recordset.BOF = False Then
Data1.Recordset.MoveFirst
Else
frame1.Enabled = True
Text1.Text = ""
Text2.Text = ""
frame1.Enabled = False
Command2.Enabled = False
End If
End If
Else
frame1.Enabled = False
Command1.Caption = "Nhập"
Command2.Caption = "Xoá"
Command3.Enabled = True
If Data1.Recordset.BOF = False Then
Data1.Recordset.MoveFirst
Else
frame1.Enabled = True
Text1.Text = ""
Text2.Text = ""
frame1.Enabled = False
Command2.Enabled = False
End If
End If
End Sub
Private Sub Command3_Click()
Unload Me
End Sub
Private Sub Data1_Reposition()
On Error GoTo loi
If kt = False Then Exit Sub
If Not IsNull(Data1.Recordset.Fields(0).Value) Then
Text1.Text = Data1.Recordset.Fields(0).Value
Else
Text1 = ""
End If
If Not IsNull(Data1.Recordset.Fields(1).Value) Then
Text2.Text = Data1.Recordset.Fields(1).Value
Else
Text2 = ""
End If
If Not IsNull(Data1.Recordset.Fields(2).Value) Then
Text3.Text = Data1.Recordset.Fields(2).Value
Else
Text3 = ""
End If
Exit Sub
loi:
If Err.Number = 3021 Then
Exit Sub
End If
End Sub
Private Sub Data1_Validate(Action As Integer, Save As Integer)
Select Case Action
Case vbDataActionMoveFirst
kt = True
Case vbDataActionMovePrevious
kt = True
Case vbDataActionMoveNext
kt = True
Case vbDataActionMoveLast
kt = True
Case vbDataActionAddNew
kt = False
Case vbDataActionUpdate
kt = True
Case vbDataActionDelete
kt = False
Case vbDataActionFind
kt = False
Case vbDataActionBookmark
Case vbDataActionClose
End Select
End Sub
Private Sub Form_Load()
Data1.DatabaseName = Loctext + "Hethong.mdb"
Data1.RecordSource = "dmkh"
Data1.Refresh
frame1.Enabled = False
If Data1.Recordset.BOF = True Then
Command2.Enabled = False
Else
Data1.Recordset.MoveFirst
End If
End Sub
Private Sub Form_Resize()
Me.Height = 3780
Me.Width = 4590
Me.Top = (Screen.Height - Me.Height) / 3
Me.Left = (Screen.Width - Me.Width) / 2
End Sub
Private Sub Text1_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text1.Text)
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text2.SetFocus
End If
End Sub
Private Sub Text2_GotFocus()
Text2.SelStart = 0
Text2.SelLength = Len(Text2.Text)
End Sub
Private Sub Text2_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text3.SetFocus
End If
End Sub
Private Sub Text3_GotFocus()
Text3.SelStart = 0
Text3.SelLength = Len(Text3.Text)
End Sub
Private Sub Text3_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Command1.SetFocus
End If
End Sub
Form Nhập liệu :
Dim kt As Boolean
Dim dk As String
Dim dk1 As String
Dim nut1 As Byte
Dim i As Byte
'Dim DK As String
Private Sub Command1_Click()
If Command1.Caption = "Nhập" Then
xoa
MaskEdBox1.Text = Date
Text1.Text = Mid(MaskEdBox1.Text, 4, 2) & "-"
Text2.Text = ""
Text12.Text = ""
Text13.Text = ""
Text5.Text = ""
Text6.Text = ""
Text7.Text = ""
Text11.Text = ""
Text10.Text = ""
'Text3.Enabled = True
'Text4.Enabled = True
Frame1.Enabled = True
Frame2.Enabled = True
Frame3.Enabled = True
MaskEdBox1.SetFocus
nut1 = 1
Command1.Caption = "Nhập tiếp"
Command2.Enabled = False
Command3.Enabled = True
Command4.Enabled = True
Command5.Enabled = False
Command6.Enabled = False
Command7.Enabled = False
Command8.Enabled = False
i = 1
Else
If Len(Text5.Text) = 0 Then
MsgBox "Mã vật tư không thể trống", vbInformation, "Chú ý"
Text5.SetFocus
Exit Sub
End If
If Len(Text7.Text) = 0 Then
MsgBox "Số lượng không thể trống", vbInformation, "Chú ý"
Text7.SetFocus
Exit Sub
End If
If Len(Text8.Text) = 0 Then
MsgBox "Đơn giá không thể trống", vbInformation, "Chú ý"
Text8.SetFocus
Exit Sub
End If
Data1.Recordset.AddNew
Data1.Recordset.Fields(0).Value = Text1.Text
Data1.Recordset.Fields(1).Value = i
Data1.Recordset.Fields(2).Value = Text5.Text
Data1.Recordset.Fields(3).Value = Text6.Text
Data1.Recordset.Fields(4).Value = Text7.Text
Data1.Recordset.Fields(5).Value = Text8.Text
Data1.Recordset.Fields(6).Value = Val(Text7.Text) * Val(Text8.Text)
Data1.Recordset.Update
Data1.Refresh
Text5.SetFocus
i = i + 1
End If
End Sub
Private Sub Command2_Click()
Data5.DatabaseName = Loctext + "ht1.mdb"
Data5.RecordSource = "lpnk1"
Data5.Refresh
Command1.Enabled = False
Command2.Enabled = False
Command3.Enabled = True
Command4.Enabled = True
Command5.Enabled = False
Command6.Enabled = False
Command7.Enabled = False
Command8.Enabled = False
Text3.Enabled = True
Text4.Enabled = True
Frame1.Enabled = True
Frame2.Enabled = True
Text3.SetFocus
nut1 = 2
End Sub
Public Sub xoa()
Data1.Refresh
If Not Data1.Recordset.BOF Then
Data1.Recordset.MoveFirst
Do While Not Data1.Recordset.EOF
Data1.Recordset.Delete
Data1.Recordset.MoveNext
Loop
End If
End Sub
Public Sub chuyen()
xoa
Set db = OpenDatabase(Loctext + "hethong.mdb")
If nut = 1 Then
db.Execute "insert into phu select mact,stt0,mavt,tenvt,soluong,dongia,tien from query1 where mact='" & Text1.Text & "'"
Else
db.Execute "insert into phu select mact,stt0,mavt,tenvt,soluong,dongia,tien from query2 where mact='" & Text1.Text & "'"
End If
db.Close
Dim tt1
tt1 = 0
Set db = OpenDatabase(Loctext + "hethong.mdb")
Set rs = db.OpenRecordset("phu")
rs.MoveFirst
Do While rs.EOF = False
tt1 = tt1 + rs.Fields("tien").Value
rs.MoveNext
Loop
rs.Close
db.Close
Text10.Text = Str(tt1)
Text11.Text = Str(tt1 / 10)
Data1.Refresh
DBGrid1.Refresh
End Sub
Private Sub Command3_Click()
If Len(Text5.Text) = 0 Then
MsgBox "Mã vật tư không thể trống", vbInformation, "Chú ý"
Text5.SetFocus
Exit Sub
End If
If Len(Text7.Text) = 0 Then
MsgBox "Số lượng không thể trống", vbInformation, "Chú ý"
Text7.SetFocus
Exit Sub
End If
If Len(Text8.Text) = 0 Then
MsgBox "Đơn giá không thể trống", vbInformation, "Chú ý"
Text8.SetFocus
Exit Sub
End If
Data1.Recordset.AddNew
Data1.Recordset.Fields(0).Value = Text1.Text
Data1.Recordset.Fields(1).Value = i
Data1.Recordset.Fields(2).Value = Text5.Text
Data1.Recordset.Fields(3).Value = Text6.Text
Data1.Recordset.Fields(4).Value = Text7.Text
Data1.Recordset.Fields(5).Value = Text8.Text
Data1.Recordset.Fields(6).Value = Val(Text7.Text) * Val(Text8.Text)
Data1.Recordset.Update
Data1.Refresh
If Len(Text1.Text) = 0 Then
MsgBox "Mã chứng từ không thể trống", vbInformation, "Thông Báo"
Text1.SetFocus
Exit Sub
End If
If Len(MaskEdBox1.Text) = 0 Then
MsgBox "Ngày nhập phiếu không thể trống", vbInformation, "Thông Báo"
MaskEdBox1.SetFocus
Exit Sub
End If
If Len(Text12.Text) = 0 Then
MsgBox "Mã kho hàng không thể trống", vbInformation, "Thông Báo"
Text12.SetFocus
Exit Sub
End If
Data2.Recordset.AddNew
Data2.Recordset.Fields(1).Value = Text1.Text
Data2.Recordset.Fields(2).Value = MaskEdBox1.Text
Data2.Recordset.Fields(3).Value = Text13.Text
Data2.Recordset.Fields(4).Value = Text12.Text
Data2.Recordset.Fields(5).Value = Text9.Text
Data2.Recordset.Fields(6).Value = Text3.Text
Data2.Recordset.Fields(7).Value = Text4.Text
Data2.Recordset.Update
Data2.Refresh
If nut = 1 Then
Set db = OpenDatabase(Loctext + "hethong.mdb")
db.Execute "Insert into ctx select mact,stt0,mavt,soluong,dongia,tien from phu"
Dim rs1 As Recordset
Set rs = db.OpenRecordset("phu")
rs.MoveFirst
Do While rs.EOF = False
Set rs1 = db.OpenRecordset("select * from tonkho where makho='" & Text12.Text & "' and mavt='" & rs.Fields(2).Value & "'")
rs1.Edit
rs1.Fields(2).Value = rs1.Fields(2).Value - rs.Fields(4).Value
rs1.Update
rs1.Close
rs.MoveNext
Loop
rs.Close
db.Close
Else
Set db = OpenDatabase(Loctext + "hethong.mdb")
db.Execute "Insert into ctnh select mact,stt0,mavt,soluong,dongia,tien from phu"
Set rs = db.OpenRecordset("phu")
rs.MoveFirst
Do While rs.EOF = False
Set rs1 = db.OpenRecordset("select * from tonkho where makho='" & Text1.Text & "' and mavt='" & rs.Fields(2).Value & "'")
If rs1.BOF = rs1.EOF And rs1.EOF = True Then
rs1.AddNew
rs1.Fields(0).Value = Text12.Text
rs1.Fields(1).Value = rs.Fields(2).Value
rs1.Fields(2).Value = rs.Fields(4).Value
rs1.Update
Else
rs1.Edit
rs1.Fields(2).Value = rs1.Fields(2).Value + rs.Fields(4).Value
rs1.Update
End If
rs1.Close
rs.MoveNext
Loop
rs.Close
db.Close
End If
Frame1.Enabled = False
Frame2.Enabled = False
Frame3.Enabled = False
Command1.Enabled = True
Command2.Enabled = True
Command3.Enabled = False
Command4.Enabled = False
Command5.Enabled = True
Command6.Enabled = True
Command7.Enabled = True
Command8.Enabled = True
Command1.Caption = "Nhập"
Data2.Recordset.MoveLast
chuyen
Command1.SetFocus
End Sub
Private Sub Command4_Click()
xoa
Command1.Enabled = True
Command1.Caption = "Nhập"
Command2.Enabled = True
If Data2.Recordset.BOF = False Then
Data2.Recordset.MoveLast
chuyen
Command3.Enabled = False
Command4.Enabled = False
Command5.Enabled = True
Else
Command5.Enabled = False
End If
Frame1.Enabled = False
Frame2.Enabled = False
Frame3.Enabled = False
Command6.Enabled = True
Command7.Enabled = True
Command8.Enabled = True
End Sub
Private Sub Command5_Click()
dk = MsgBox("Bạn có chắc chắn xoá không ?", vbCritical + vbYesNo, "Chú ý")
If dk = vbYes Then
Data2.Recordset.Delete
Data2.Refresh
If Data2.Recordset.BOF Then
Command5.Enabled = False
End If
End If
End Sub
Private Sub Command6_Click()
Set db = OpenDatabase(Loctext + "hethong")
db.Execute "delete * from table1"
Set rs = db.OpenRecordset("table1")
rs.AddNew
rs.Fields(0).Value = Text1.Text
rs.Update
rs.Close
db.Close
If Label1.Caption = "Phiếu Xuất Kho" Then
CrystalReport1.DataFiles(0) = Loctext & "hethong.mdb"
CrystalReport1.ReportFileName = Loctext$ + "px.rpt"
Else
CrystalReport1.DataFiles(0) = Loctext & "hethong.mdb"
CrystalReport1.ReportFileName = Loctext$ + "pnh.rpt"
End If
On Error GoTo ErrorHandler
CrystalReport1.Action = 1
Screen.MousePointer = 0
Exit Sub
ErrorHandler:
MsgBox CrystalReport1.LastErrorString
Screen.MousePointer = 0
Exit Sub
End Sub
Private Sub Command7_Click()
dktk.Show 1
dk = "mact='" & ma & "'"
Data2.Recordset.FindFirst dk
Data2.Recordset.MoveNext
Data2.Recordset.MovePrevious
chuyen
End Sub
Private Sub Command8_Click()
Unload Me
End Sub
Private Sub Data2_Reposition()
'On Error GoTo loi
If kt = False Then Exit Sub
If Not IsNull(Data2.Recordset.Fields(1).Value) Then
Text1.Text = Data2.Recordset.Fields(1).Value
Else
Text1 = ""
End If
If Not IsNull(Data2.Recordset.Fields(2).Value) Then
MaskEdBox1.Text = Data2.Recordset.Fields(2).Value
Else
MaskEdBox1.Text = "__/__/____"
End If
If Not IsNull(Data2.Recordset.Fields(3).Value) Then
Text13.Text = Data2.Recordset.Fields(3).Value
Else
Text13 = ""
End If
Set db = OpenDatabase(Loctext + "hethong.mdb")
Set rs = db.OpenRecordset("select * from dmkh where makh='" & Text13.Text & "'")
Text2.Text = rs.Fields(1).Value
rs.Close
db.Close
If Not IsNull(Data2.Recordset.Fields(4).Value) Then
Text12.Text = Data2.Recordset.Fields(4).Value
Else
Text12 = ""
End If
If Not IsNull(Data2.Recordset.Fields(6).Value) Then
Text3.Text = Data2.Recordset.Fields(6).Value
Else
Text3 = ""
End If
If Not IsNull(Data2.Recordset.Fields(7).Value) Then
Text4.Text = Data2.Recordset.Fields(7).Value
Else
Text4 = ""
End If
If Not IsNull(Data2.Recordset.Fields(5).Value) Then
Text9.Text = Data2.Recordset.Fields(5).Value
Else
Text9 = ""
End If
chuyen
' DBGrid1.SetFocus
Exit Sub
loi:
If Err.Number = 3021 Then
Exit Sub
End If
End Sub
Private Sub Data2_Validate(Action As Integer, Save As Integer)
Select Case Action
Case vbDataActionMoveFirst
kt = True
Case vbDataActionMovePrevious
kt = True
Case vbDataActionMoveNext
kt = True
Case vbDataActionMoveLast
kt = True
Case vbDataActionAddNew
kt = False
Case vbDataActionUpdate
kt = False
Case vbDataActionDelete
kt = True
Case vbDataActionFind
kt = False
Case vbDataActionBookmark
Case vbDataActionClose
End Select
End Sub
Private Sub Form_Load()
Frame1.Enabled = False
Frame2.Enabled = False
Frame3.Enabled = False
Frame4.Enabled = False
Command3.Enabled = False
Command4.Enabled = False
If nut = 1 Then
Label1.Caption = "Phiếu Xuất Kho"
Data1.DatabaseName = Loctext + "Hethong.mdb"
Data1.RecordSource = "phu"
Data1.Refresh
Data2.DatabaseName = Loctext + "Hethong.mdb"
Data2.RecordSource = "phieux"
Data2.Refresh
'Data3.DatabaseName = Loctext + "hethong.mdb"
'Data3.RecordSource = "ctx"
'Data3.Refresh
xoa
If Data2.Recordset.BOF = False Then
Data2.Recordset.MoveLast
chuyen
Else
Command5.Enabled = False
End If
Else
Label1.Caption = "Phiếu Nhập Kho"
Data1.DatabaseName = Loctext + "Hethong.mdb"
Data1.RecordSource = "phu"
Data1.Refresh
Data2.DatabaseName = Loctext + "Hethong.mdb"
Data2.RecordSource = "phieunh"
Data2.Refresh
xoa
If Data2.Recordset.BOF = False Then
Data2.Recordset.MoveLast
chuyen
Else
Command5.Enabled = False
End If
End If
End Sub
Private Sub Form_Resize()
Me.Width = 8100
Me.Height = 5145
Me.Top = 0
Me.Left = (Screen.Width - Me.Width) / 2
End Sub
Private Sub MaskEdBox1_GotFocus()
MaskEdBox1.SelStart = 0
MaskEdBox1.SelLength = Len(MaskEdBox1.Text)
End Sub
Private Sub MaskEdBox1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text1.SetFocus
End If
End Sub
Private Sub Text1_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text1.Text)
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text12.SetFocus
End If
End Sub
Private Sub Text12_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text12.Text)
End Sub
Private Sub Text12_KeyPress(KeyAscii As Integer)
KeyAscii = 0
tck.Show 1
Text12.Text = ma
Text13.SetFocus
End Sub
Private Sub Text13_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text13.Text)
End Sub
Private Sub Text13_KeyPress(KeyAscii As Integer)
KeyAscii = 0
Text2.SetFocus
End Sub
Private Sub Text2_GotFocus()
Dim dk As String
If Len(Text2.Text) = 0 Then
ttt.Show 1
Text13.Text = ma
Text2.Text = ten
Text9.SetFocus
End If
End Sub
Private Sub Text2_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Command1.SetFocus
End If
End Sub
Private Sub Text3_GotFocus()
Text3.SelStart = 0
Text3.SelLength = Len(Text3.Text)
End Sub
Private Sub Text3_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text4.SetFocus
End If
End Sub
Private Sub Text4_GotFocus()
Text4.SelStart = 0
Text4.SelLength = Len(Text4.Text)
End Sub
Private Sub Text4_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text5.SetFocus
End If
End Sub
Private Sub Text5_GotFocus()
Text5.SelStart = 0
Text5.SelLength = Len(Text5.Text)
End Sub
Private Sub Text5_KeyPress(KeyAscii As Integer)
KeyAscii = 0
Text6.SetFocus
End Sub
Private Sub Text6_GotFocus()
If Len(Text5.Text) = 0 Then
tt.Show 1
Text5.Text = ma
Text6.Text = ten
Text7.SetFocus
End If
End Sub
Private Sub Text6_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text17.SetFocus
End If
End Sub
Private Sub Text7_GotFocus()
Text7.SelStart = 0
Text7.SelLength = Len(Text7.Text)
End Sub
Private Sub Text7_KeyDown(KeyCode As Integer, Shift As Integer)
If (KeyCode 57) And KeyCode 13 And KeyCode 37 And KeyCode 39 And KeyCode 46 And KeyCode 8 Then
KeyCode = 0
End If
End Sub
Private Sub Text7_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text8.SetFocus
Else
If (KeyAscii 57) And KeyAscii 37 And KeyAscii 39 And KeyAscii 46 And KeyAscii 8 Then
KeyAscii = 0
End If
End If
End Sub
Private Sub Text8_GotFocus()
Text8.SelStart = 0
Text8.SelLength = Len(Text8.Text)
End Sub
Private Sub Text8_KeyDown(KeyCode As Integer, Shift As Integer)
If (KeyCode 57) And KeyCode 13 And KeyCode 37 And KeyCode 39 And KeyCode 46 And KeyCode 8 Then
KeyCode = 0
End If
End Sub
Private Sub Text8_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Command1.SetFocus
Else
If (KeyAscii 57) And KeyAscii 37 And KeyAscii 39 And KeyAscii 46 And KeyAscii 8 Then
KeyAscii = 0
End If
End If
End Sub
Private Sub Text9_GotFocus()
Text9.SelStart = 0
Text9.SelLength = Len(Text9.Text)
End Sub
Private Sub Text9_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text3.SetFocus
End If
End Sub
II. Form màn hình chính :
Dim kt As Boolean
Dim dk As String
Dim dk1 As String
Dim nut1 As Byte
Dim i As Byte
'Dim DK As String
Private Sub Command1_Click()
If Command1.Caption = "Nhập" Then
xoa
MaskEdBox1.Text = Date
Text1.Text = Mid(MaskEdBox1.Text, 4, 2) & "-"
Text2.Text = ""
Text12.Text = ""
Text13.Text = ""
Text5.Text = ""
Text6.Text = ""
Text7.Text = ""
Text11.Text = ""
Text10.Text = ""
Frame1.Enabled = True
Frame2.Enabled = True
Frame3.Enabled = True
MaskEdBox1.SetFocus
nut1 = 1
Command1.Caption = "Nhập tiếp"
Command2.Enabled = False
Command3.Enabled = True
Command4.Enabled = True
Command5.Enabled = False
Command6.Enabled = False
Command7.Enabled = False
Command8.Enabled = False
'Data1.Recordset.AddNew
i = 1
Else
If Len(Text5.Text) = 0 Then
MsgBox "Mã vật tư không thể trống", vbInformation, "Chú ý"
Text5.SetFocus
Exit Sub
End If
If Len(Text7.Text) = 0 Then
MsgBox "Số lượng không thể trống", vbInformation, "Chú ý"
Text7.SetFocus
Exit Sub
End If
If Len(Text8.Text) = 0 Then
MsgBox "Đơn giá không thể trống", vbInformation, "Chú ý"
Text8.SetFocus
Exit Sub
End If
Data1.Recordset.AddNew
Data1.Recordset.Fields(0).Value = Text1.Text
Data1.Recordset.Fields(1).Value = i
Data1.Recordset.Fields(2).Value = Text5.Text
Data1.Recordset.Fields(3).Value = Text6.Text
Data1.Recordset.Fields(4).Value = Text7.Text
Data1.Recordset.Fields(5).Value = Text8.Text
Data1.Recordset.Fields(6).Value = Val(Text7.Text) * Val(Text8.Text)
Data1.Recordset.Update
Data1.Refresh
Text5.SetFocus
i = i + 1
End If
End Sub
Private Sub Command2_Click()
Data5.DatabaseName = Loctext + "ht1.mdb"
Data5.RecordSource = "lpnk1"
Data5.Refresh
Command1.Enabled = False
Command2.Enabled = False
Command3.Enabled = True
Command4.Enabled = True
Command5.Enabled = False
Command6.Enabled = False
Command7.Enabled = False
Command8.Enabled = False
Text3.Enabled = True
Text4.Enabled = True
Frame1.Enabled = True
Frame2.Enabled = True
Text3.SetFocus
nut1 = 2
End Sub
Public Sub xoa()
Data1.Refresh
If Not Data1.Recordset.BOF Then
Data1.Recordset.MoveFirst
Do While Not Data1.Recordset.EOF
Data1.Recordset.Delete
Data1.Recordset.MoveNext
Loop
End If
End Sub
Public Sub chuyen()
xoa
Set db = OpenDatabase(Loctext + "hethong.mdb")
If nut = 1 Then
db.Execute "insert into phu select mact,stt0,mavt,tenvt,soluong,dongia,tien from query1 where mact='" & Text1.Text & "'"
Else
db.Execute "insert into phu select mact,stt0,mavt,tenvt,soluong,dongia,tien from query2 where mact='" & Text1.Text & "'"
End If
'db.Execute "insert into phu select mact,stt0,mavt,tenvt,soluong,dongia,tien form query1"
db.Close
Dim tt1
tt1 = 0
' db.Close
Set db = OpenDatabase(Loctext + "hethong.mdb")
Set rs = db.OpenRecordset("phu")
rs.MoveFirst
Do While rs.EOF = False
tt1 = tt1 + rs.Fields("tien").Value
rs.MoveNext
Loop
rs.Close
db.Close
Text10.Text = Str(tt1)
Text11.Text = Str(tt1 / 10)
Data1.Refresh
DBGrid1.Refresh
End Sub
Private Sub Command3_Click()
If Len(Text5.Text) = 0 Then
MsgBox "Mã vật tư không thể trống", vbInformation, "Chú ý"
Text5.SetFocus
Exit Sub
End If
If Len(Text7.Text) = 0 Then
MsgBox "Số lượng không thể trống", vbInformation, "Chú ý"
Text7.SetFocus
Exit Sub
End If
If Len(Text8.Text) = 0 Then
MsgBox "Đơn giá không thể trống", vbInformation, "Chú ý"
Text8.SetFocus
Exit Sub
End If
Data1.Recordset.AddNew
Data1.Recordset.Fields(0).Value = Text1.Text
Data1.Recordset.Fields(1).Value = i
Data1.Recordset.Fields(2).Value = Text5.Text
Data1.Recordset.Fields(3).Value = Text6.Text
Data1.Recordset.Fields(4).Value = Text7.Text
Data1.Recordset.Fields(5).Value = Text8.Text
Data1.Recordset.Fields(6).Value = Val(Text7.Text) * Val(Text8.Text)
Data1.Recordset.Update
Data1.Refresh
If Len(Text1.Text) = 0 Then
MsgBox "Mã chứng từ không thể trống", vbInformation, "Thông Báo"
Text1.SetFocus
Exit Sub
End If
If Len(MaskEdBox1.Text) = 0 Then
MsgBox "Ngày nhập phiếu không thể trống", vbInformation, "Thông Báo"
MaskEdBox1.SetFocus
Exit Sub
End If
If Len(Text12.Text) = 0 Then
MsgBox "Mã kho hàng không thể trống", vbInformation, "Thông Báo"
Text12.SetFocus
Exit Sub
End If
Data2.Recordset.AddNew
Data2.Recordset.Fields(1).Value = Text1.Text
Data2.Recordset.Fields(2).Value = MaskEdBox1.Text
Data2.Recordset.Fields(3).Value = Text13.Text
Data2.Recordset.Fields(4).Value = Text12.Text
Data2.Recordset.Fields(5).Value = Text9.Text
Data2.Recordset.Fields(6).Value = Text3.Text
Data2.Recordset.Fields(7).Value = Text4.Text
Data2.Recordset.Update
Data2.Refresh
If nut = 1 Then
Set db = OpenDatabase(Loctext + "hethong.mdb")
db.Execute "Insert into ctx select mact,stt0,mavt,soluong,dongia,tien from phu"
Dim rs1 As Recordset
Set rs = db.OpenRecordset("phu")
rs.MoveFirst
Do While rs.EOF = False
Set rs1 = db.OpenRecordset("select * from tonkho where makho='" & Text12.Text & "' and mavt='" & rs.Fields(2).Value & "'")
rs1.Edit
rs1.Fields(2).Value = rs1.Fields(2).Value - rs.Fields(4).Value
rs1.Update
rs1.Close
rs.MoveNext
Loop
rs.Close
db.Close
Else
Set db = OpenDatabase(Loctext + "hethong.mdb")
db.Execute "Insert into ctnh select mact,stt0,mavt,soluong,dongia,tien from phu"
Set rs = db.OpenRecordset("phu")
rs.MoveFirst
Do While rs.EOF = False
Set rs1 = db.OpenRecordset("select * from tonkho where makho='" & Text1.Text & "' and mavt='" & rs.Fields(2).Value & "'")
If rs1.BOF = rs1.EOF And rs1.EOF = True Then
rs1.AddNew
rs1.Fields(0).Value = Text12.Text
rs1.Fields(1).Value = rs.Fields(2).Value
rs1.Fields(2).Value = rs.Fields(4).Value
rs1.Update
Else
rs1.Edit
rs1.Fields(2).Value = rs1.Fields(2).Value + rs.Fields(4).Value
rs1.Update
End If
rs1.Close
rs.MoveNext
Loop
rs.Close
db.Close
End If
Frame1.Enabled = False
Frame2.Enabled = False
Frame3.Enabled = False
Command1.Enabled = True
Command2.Enabled = True
Command3.Enabled = False
Command4.Enabled = False
Command5.Enabled = True
Command6.Enabled = True
Command7.Enabled = True
Command8.Enabled = True
Command1.Caption = "Nhập"
Data2.Recordset.MoveLast
chuyen
Command1.SetFocus
End Sub
Private Sub Command4_Click()
xoa
Command1.Enabled = True
Command1.Caption = "Nhập"
Command2.Enabled = True
If Data2.Recordset.BOF = False Then
Data2.Recordset.MoveLast
chuyen
Command3.Enabled = False
Command4.Enabled = False
Command5.Enabled = True
Else
Command5.Enabled = False
End If
Frame1.Enabled = False
Frame2.Enabled = False
Frame3.Enabled = False
Command6.Enabled = True
Command7.Enabled = True
Command8.Enabled = True
End Sub
Private Sub Command5_Click()
dk = MsgBox("Bạn có chắc chắn xoá không ?", vbCritical + vbYesNo, "Chú ý")
If dk = vbYes Then
Data2.Recordset.Delete
Data2.Refresh
If Data2.Recordset.BOF Then
Command5.Enabled = False
End If
End If
End Sub
Private Sub Command6_Click()
Set db = OpenDatabase(Loctext + "hethong")
db.Execute "delete * from table1"
Set rs = db.OpenRecordset("table1")
rs.AddNew
rs.Fields(0).Value = Text1.Text
rs.Update
rs.Close
'rs.Close
db.Close
If Label1.Caption = "Phiếu Xuất Kho" Then
CrystalReport1.DataFiles(0) = Loctext & "hethong.mdb"
CrystalReport1.ReportFileName = Loctext$ + "px.rpt"
Else
CrystalReport1.DataFiles(0) = Loctext & "hethong.mdb"
CrystalReport1.ReportFileName = Loctext$ + "pnh.rpt"
End If
On Error GoTo ErrorHandler
CrystalReport1.Action = 1
Screen.MousePointer = 0
Exit Sub
ErrorHandler:
MsgBox CrystalReport1.LastErrorString
Screen.MousePointer = 0
Exit Sub
End Sub
Private Sub Command7_Click()
dktk.Show 1
dk = "mact='" & ma & "'"
Data2.Recordset.FindFirst dk
Data2.Recordset.MoveNext
Data2.Recordset.MovePrevious
chuyen
End Sub
Private Sub Command8_Click()
Unload Me
End Sub
Private Sub Data2_Reposition()
'On Error GoTo loi
If kt = False Then Exit Sub
If Not IsNull(Data2.Recordset.Fields(1).Value) Then
Text1.Text = Data2.Recordset.Fields(1).Value
Else
Text1 = ""
End If
If Not IsNull(Data2.Recordset.Fields(2).Value) Then
MaskEdBox1.Text = Data2.Recordset.Fields(2).Value
Else
MaskEdBox1.Text = "__/__/____"
End If
If Not IsNull(Data2.Recordset.Fields(3).Value) Then
Text13.Text = Data2.Recordset.Fields(3).Value
Else
Text13 = ""
End If
Set db = OpenDatabase(Loctext + "hethong.mdb")
Set rs = db.OpenRecordset("select * from dmkh where makh='" & Text13.Text & "'")
Text2.Text = rs.Fields(1).Value
rs.Close
db.Close
If Not IsNull(Data2.Recordset.Fields(4).Value) Then
Text12.Text = Data2.Recordset.Fields(4).Value
Else
Text12 = ""
End If
If Not IsNull(Data2.Recordset.Fields(6).Value) Then
Text3.Text = Data2.Recordset.Fields(6).Value
Else
Text3 = ""
End If
If Not IsNull(Data2.Recordset.Fields(7).Value) Then
Text4.Text = Data2.Recordset.Fields(7).Value
Else
Text4 = ""
End If
If Not IsNull(Data2.Recordset.Fields(5).Value) Then
Text9.Text = Data2.Recordset.Fields(5).Value
Else
Text9 = ""
End If
chuyen
' DBGrid1.SetFocus
Exit Sub
loi:
If Err.Number = 3021 Then
Exit Sub
End If
End Sub
Private Sub Data2_Validate(Action As Integer, Save As Integer)
Select Case Action
Case vbDataActionMoveFirst
kt = True
Case vbDataActionMovePrevious
kt = True
Case vbDataActionMoveNext
kt = True
Case vbDataActionMoveLast
kt = True
Case vbDataActionAddNew
kt = False
Case vbDataActionUpdate
kt = False
Case vbDataActionDelete
kt = True
Case vbDataActionFind
kt = False
Case vbDataActionBookmark
Case vbDataActionClose
End Select
End Sub
Private Sub Form_Load()
Frame1.Enabled = False
Frame2.Enabled = False
Frame3.Enabled = False
Frame4.Enabled = False
Command3.Enabled = False
Command4.Enabled = False
If nut = 1 Then
Label1.Caption = "Phiếu Xuất Kho"
Data1.DatabaseName = Loctext + "Hethong.mdb"
Data1.RecordSource = "phu"
Data1.Refresh
Data2.DatabaseName = Loctext + "Hethong.mdb"
Data2.RecordSource = "phieux"
Data2.Refresh
'Data3.DatabaseName = Loctext + "hethong.mdb"
'Data3.RecordSource = "ctx"
'Data3.Refresh
xoa
If Data2.Recordset.BOF = False Then
Data2.Recordset.MoveLast
chuyen
Else
Command5.Enabled = False
End If
Else
Label1.Caption = "Phiếu Nhập Kho"
Data1.DatabaseName = Loctext + "Hethong.mdb"
Data1.RecordSource = "phu"
Data1.Refresh
Data2.DatabaseName = Loctext + "Hethong.mdb"
Data2.RecordSource = "phieunh"
Data2.Refresh
xoa
If Data2.Recordset.BOF = False Then
Data2.Recordset.MoveLast
chuyen
Else
Command5.Enabled = False
End If
End If
End Sub
Private Sub Form_Resize()
Me.Width = 8100
Me.Height = 5145
Me.Top = 0
Me.Left = (Screen.Width - Me.Width) / 2
End Sub
Private Sub MaskEdBox1_GotFocus()
MaskEdBox1.SelStart = 0
MaskEdBox1.SelLength = Len(MaskEdBox1.Text)
End Sub
Private Sub MaskEdBox1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text1.SetFocus
End If
End Sub
Private Sub Text1_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text1.Text)
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text12.SetFocus
End If
End Sub
Private Sub Text12_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text12.Text)
End Sub
Private Sub Text12_KeyPress(KeyAscii As Integer)
KeyAscii = 0
tck.Show 1
Text12.Text = ma
Text13.SetFocus
End Sub
Private Sub Text13_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text13.Text)
End Sub
Private Sub Text13_KeyPress(KeyAscii As Integer)
KeyAscii = 0
Text2.SetFocus
End Sub
Private Sub Text2_GotFocus()
Dim dk As String
If Len(Text2.Text) = 0 Then
ttt.Show 1
Text13.Text = ma
Text2.Text = ten
Text9.SetFocus
End If
End Sub
Private Sub Text2_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Command1.SetFocus
End If
End Sub
Private Sub Text3_GotFocus()
Text3.SelStart = 0
Text3.SelLength = Len(Text3.Text)
End Sub
Private Sub Text3_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text4.SetFocus
End If
End Sub
Private Sub Text4_GotFocus()
Text4.SelStart = 0
Text4.SelLength = Len(Text4.Text)
End Sub
Private Sub Text4_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text5.SetFocus
End If
End Sub
Private Sub Text5_GotFocus()
Text5.SelStart = 0
Text5.SelLength = Len(Text5.Text)
End Sub
Private Sub Text5_KeyPress(KeyAscii As Integer)
KeyAscii = 0
Text6.SetFocus
End Sub
Private Sub Text6_GotFocus()
If Len(Text5.Text) = 0 Then
tt.Show 1
Text5.Text = ma
Text6.Text = ten
Text7.SetFocus
End If
End Sub
Private Sub Text6_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text17.SetFocus
End If
End Sub
Private Sub Text7_GotFocus()
Text7.SelStart = 0
Text7.SelLength = Len(Text7.Text)
End Sub
Private Sub Text7_KeyDown(KeyCode As Integer, Shift As Integer)
If (KeyCode 57) And KeyCode 13 And KeyCode 37 And KeyCode 39 And KeyCode 46 And KeyCode 8 Then
KeyCode = 0
End If
End Sub
Private Sub Text7_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text8.SetFocus
Else
If (KeyAscii 57) And KeyAscii 37 And KeyAscii 39 And KeyAscii 46 And KeyAscii 8 Then
KeyAscii = 0
End If
End If
End Sub
Private Sub Text8_GotFocus()
Text8.SelStart = 0
Text8.SelLength = Len(Text8.Text)
End Sub
Private Sub Text8_KeyDown(KeyCode As Integer, Shift As Integer)
If (KeyCode 57) And KeyCode 13 And KeyCode 37 And KeyCode 39 And KeyCode 46 And KeyCode 8 Then
KeyCode = 0
End If
End Sub
Private Sub Text8_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Command1.SetFocus
Else
If (KeyAscii 57) And KeyAscii 37 And KeyAscii 39 And KeyAscii 46 And KeyAscii 8 Then
KeyAscii = 0
End If
End If
End Sub
Private Sub Text9_GotFocus()
Text9.SelStart = 0
Text9.SelLength = Len(Text9.Text)
End Sub
Private Sub Text9_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text3.SetFocus
End If
End Sub
Form DKTK (Tìm kiếm) :
Private Sub Combo1_Click()
Combo2.SetFocus
End Sub
Private Sub Combo1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Combo2.SetFocus
End If
End Sub
Private Sub Combo2_Click()
Text1.SetFocus
End Sub
Private Sub Combo2_GotFocus()
Combo2.AddItem ("=")
Combo2.AddItem (">")
Combo2.AddItem ("<")
End Sub
Private Sub Combo2_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Text1.SetFocus
End If
End Sub
Private Sub Command1_Click()
Dim da As Date
Select Case nut
Case 1:
If Combo1.Text = "Mã chứng từ" Then
Data1.DatabaseName = Loctext + "hethong.mdb"
Data1.RecordSource = "select ngay,mact from phieux where mact " & Combo2.Text & "'" & Text1.Text & "'"
Data1.Refresh
Else
da = Text1.Text
Data1.DatabaseName = Loctext + "hethong.mdb"
dk = "select ngay,mact from phieux where ngay " & Combo2.Text & " #" & da & "#"
Data1.RecordSource = dk
Data1.Refresh
End If
Case 2:
If Combo1.Text = "Mã chứng từ" Then
Data1.DatabaseName = Loctext + "hethong.mdb"
Data1.RecordSource = "select ngay,mact from phieunh where mact " & Combo2.Text & "'" & Text1.Text & "'"
Data1.Refresh
Else
da = Text1.Text
Data1.DatabaseName = Loctext + "hethong.mdb"
dk = "select ngay,mact from phieunh where ngay " & Combo2.Text & " #" & da & "#"
Data1.RecordSource = dk
Data1.Refresh
End If
Case 3:
If Combo1.Text = "Mã chứng từ" Then
Data1.DatabaseName = Loctext + "hethong.mdb"
Data1.RecordSource = "select ngay,mact from phieulc where mact " & Combo2.Text & "'" & Text1.Text & "'"
Data1.Refresh
Else
da = Text1.Text
Data1.DatabaseName = Loctext + "hethong.mdb"
dk = "select ngay,mact from phieulc where ngay " & Combo2.Text & " #" & da & "#"
Data1.RecordSource = dk
Data1.Refresh
End If
End Select
If Data1.Recordset.BOF = False Then
Command3.Enabled = True
Command1.Enabled = False
End If
End Sub
Private Sub Command2_Click()
Unload Me
End Sub
Private Sub Command3_Click()
ma = Data1.Recordset.Fields(1).Value
ten = Data1.Recordset.Fields(0).Value
Unload Me
End Sub
Private Sub DBGrid1_DblClick()
Command3_Click
End Sub
Private Sub Form_Load()
Combo1.AddItem ("Mã chứng từ")
Combo1.AddItem ("Ngày Nhập Phiếu")
Command3.Enabled = False
'Combo1.Text = ""
End Sub
Private Sub Form_Resize()
Me.Height = 3510
Me.Width = 5370
End Sub
Private Sub Text1_GotFocus()
Text1.SelStart = 0
Text1.SelLength = Len(Text1.Text)
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Command1.SetFocus
End If
End Sub
MỤC LỤC
LỜI NÓI ĐẦU 1
CHƯƠNG I: CÔNG TY PHẦN MỀM TÀI CHÍNH KẾ TOÁN FAST VÀ BÀI TOÁN QUẢN LÝ KHO HÀNG TRONG HỆ THÔNG TIN KẾ TOÁN 3
Vài nét về lịch sử thành lập công ty 3
Bài toán xây dựng phân hệ thông tin quản lý kho hàng trong hệ thông tin kế toán 9
Môi trường và công cụ........................................................................... 12
CHƯƠNG II : KHẢO SÁT THỰC TẾ 16
I. Tóm tắt chức năng, nhiệm vụ, tổ chức và các quy trình nghiệp vụ của một công ty trong quản lý kho hàng 17
II.Mô tả hệ thống thông tin điều hành và quản lý 19
CHƯƠNG III: PHÂN TÍCH VÀ THIẾT KẾ HỆ THỐNG 30
Phân tích hệ thống 30
Cấu trúc dữ liệu 36
Cấu trúc chương trình 44
Một số thuật toán trong chương trình 46
Xây dựng chương trình 50
KẾT LUẬN 60
PHỤ LỤC 62
TÀI LIỆU THAM KHẢO
Kỹ thuật lập trình Access trên Windows - Phạm Văn Ất - NXB Khoa học
Kỹ thuật
2. Microsoft Access 97 Visual Basic for application từ A đến Z - Trần Thanh
Phong - NXB Thống kê
3. Bài giảng Cơ sở dữ liệu - Trần Công Uẩn
4. Giáo trình Hệ thống thông tin quản lý- Trương Văn Tú
5. Phân tích và thiết kế tin học hệ thống quản lý, kinh doanh, nghiệp vụ -
NXB Giao thông Vận tải
6. Visual Basic 6.0
7. Tạp chí PC World Việt Nam
Các file đính kèm theo tài liệu này:
- bc_quan_ly_kho_theo_vb_4993.doc