1、1 摘要 随着小型 超市 快速的 发展 ,商品数量 急速 增加,有关商品的各种信息 也成倍增长。 小型 超市 也 需要对商品各种信息进行统计分析。而大型的超市管理系统功能过于强大而造成操作繁琐降低了小型超市的工作效率。 小型 超市管理系统是市场上最流行的 、 超市上常用的系统之一, 它主要包含以下几个模块:进货和退货管理模块、销售模块、库存模块、人事管理模块、系统模块。它可以使进货、库存、销售、员工信息接受全面、动态、及时的管理。 经过分析 ,使用 JAVA 语言为开发工具 ,使用 SQL server 2008 作为数据库 ,利用它们在开发数据库应用程序方面的众多优越性 ,尤其是 JAVA
2、在应用程序应用开发方面提供了大量的用于数据库应用开发的各种组件,大大提高开发的效率。不断修正和改进 ,在用户要求的时间内 完成可用 系统。 本文分析了软件开发的背景以及过程, 首先介绍了软件的开发环境,其次介绍了本软件的 总体设计过程、 详细设计过程:数据库的设计、各个模块的设计和实现,以及具体界面的设计和功能。 关键词 : 超市管理系统 ; JAVA; SQL server 2008; 数据库 2 Abstract With the rapid development of small supermarkets, a quick increase in the number of goods
3、, the goods of all kinds of information also doubled.Small supermarketalso needs to carry out statistical analysis of all kinds of information. The large supermarket management system is too cumbersome to operate a strong and resulted in reducing the efficiency of the small supermarket. Small superm
4、arket management system is the most popular markets, also is one of the commonly used.It contains the following modules: purchase and returns management module, sales module, inventory module, the Personnel Management module, the system module. It can make the purchase, inventory, sales, employees u
5、ndergo a comprehensive, dynamic and timely management. Afteranalysis, the use of JAVA language for the development of tools, the use of SQL server 2008 as a database, the use of their database applications in the development of numerous advantages, especially in JAVA application development in the a
6、pplication provide a large number of database application development for a variety of group cases, greatly enhanced the efficiency of development. Constantly revised and improved, inthe timethe user requests to finish aavailable system. This paper analyzes the background, as well as software develo
7、pment process, first introduced the software development environment, followed by introduction of the software design process, detailed design process: database design, each module of the design and implementation, as well as the specific interfaces design and functionality Key words:SupermarketMana
8、gement System ; JAVA ; SQL server 2008; Database 3 1 绪论 1.1 社会背景 随着现代科学技术的迅猛发展,计算机技术已经渗透到各个领域,成为各行业必不可少的工具, 信息全球化的时代已经来临, 超市的竞争也进入到了一个全新的领域,竞争已不再是规模的竞争,而是技术的竞争、管理的竞争、人才的竞争。技术的提升和管理的升级是超市业的竞争核心。零售领域目前呈多元发展趋势,多种业态:超市、仓储店、便利店、特许加盟店、专卖店、货仓等相互并存。如何在激烈的竞争中扩大销售额、降低经营成本、扩大经营规模,成为超市营业者努力追求的目标。 当今的 小型超市,它们信息化
9、的速度、资金、技术等都比不上大中型超市,但是对于这些 小超市 的资源管理,信息的存储和处理 也是非常必要的 ,要适应市场竞争,就需要有高效的处理方式和管理方法 来提高劳动生产效率 , 才能获得最大的经济效益, 因此加快小型超市的信息化进程也是必不可少的。 小型超市管理系统是小型超市商品销售及货物管理的主要控制部分,直接影响销售的方便性及管理的规范性。随着信息时代的发展,对效率的要求日益提高,因而软件控制销售和管理已经取代了传统全手工方式。小型超市具有自身 的特点:商品要求一般齐全,进出货关系较为简单,员工人数种类不多, 但正由于员工较少,使用软件控制成为必须。 1.2 超市背景 在我国超市形成
10、在 20 世纪 90 年代初期,现在已经成为我国零售业的一种重要形态,为国民经济的发展发挥了重要的作用。随着超市高速的发展,其经营管理也变得愈加复杂,早期的售货员站柜台的形式早已不能满足现有销售也的发展,这样就迫切地需要引入新的管理技术。 超市形态具有种种优点,但在目前状况下,它仍存在零售业企业所共有的落后的一面,如:不能有效地管理每种商品,收款结算速度慢,容易出现营业差错,不宜进行商品调价,盘点效率低等,而且在超市日常管理中,商品的进、销、存等决策以经验为主,缺乏实时分析功能,管理人 员对及时传递资料的要求始终得不到满足。苏辙超市形态的高速发展,其经营管理也变得愈加复杂,日常所需要处理的数据
11、量也逐渐增大,商业运转的中间环节也越来越多,原始的人工管理已无法应对这复杂的市场。 1.3 系统开发背景 随着科学技术的发展,新颖的图形用户界面、卓越的多任务操作系统性能、高层次的软件开发平台风靡全球。人们要求的不断提高,可视化的图形用户界面对比原来的结构化程序设计语言更为简单易用,且编程系统采用面向对象、事件驱动的编程机制,提供了一4 种所见即所得的可视界面设计方法。在众多的编程语言中, java 可以快速地创建 图形界面应用程序 , 结合 MyEclipse,可以快速地将系统开发完成。 1.4 课题研究的目的 和 意义 (1)大大提高 小型 超市的运作效率 。 (2)通过 全面的信息采集和
12、处理 , 辅助提高 小型 超市的决策水平 。 (3)使用本系统,可以迅速提升小型超市的管理水平,为降低经营成本, 提高效益,增强超市扩张能力, 提供有效的技术保障 1.5 系统功能特点 进货 退货 管理: 包括 进行商品采购入库,采购退货,进退 信息 查询,与供货商的往来 账务 。 销售管理 :包括 进行商品销售, 销售信息进销售列表,当前销售信息 查询, 当期销售总金额 统计,与客户的往来 账务 。 库存管理 :包括库存 商品信息的修改, 库存 查询和 盘点功能。 人事管理 :包括员工信息和供应商信息的管理。 系统 管理 : 包括 数据库备份恢复,系统初始化, 用户信息管理。 1.6 本文主
13、要工作 第一章是绪论,主要 写 了小型超市发展的社会背景、超市本身的发展状况、系统开发的背景、课题研究的目的和意义、系统功能特点以及本文的主要工作。 第二章是系统可行性研究,主要 分析 了系统的技术可行性、经济可行性 和操作可行性。 第三章是系统需求分析,主要写了超市基本业务分析、系统功能需求分析以及性能需求分析。 第四章是系统总体设计,主要写了设计思想、设计原则、系统模块概要设计以及系统操作流程概要设计。 第五章是系统详细设计,主要写了系统功能详细设计、系统数据库设计、系统子模块功能的详细设计。 第六章是系统测试,主要写了系统的测试方法、系统的功能模块测试以及系统的整体测试。 最后是本文的结
14、束语、参考文献和致谢辞。 5 2 系统可行性研究 2.1 技术可行性研究 2.1.1采用 java 语言编写 系统使用 JAVA 语言编写, JAVA 具有很多优点 :简单、安全、小巧、健全、面向对象、静态类型,而且 JAVA 具有强大的标准库支持,文件的读取和保存操作、快捷方便的数据库接口、图形操作界面的实现有 java.swing.*等使用方便的包,包含了 JComponent、 JFrame、JApplet、 JDialog 四个功能强大的父类, JPanel、 JScrollPane、 JSplitPane、 JInternalFrame四个使用方便的中间容器, JButton、 JL
15、abel、 JCheckBox、 JRadioButton、 JComboBox、JTextField、 JPasswordField、 JTextArea、 JFileChooser 等功能强大、灵活性高的组件,完全可以满足小型超市管理系统的功能要求,结合一种快速开发的 IDE,比如 MyEclipse,采用一种方便快捷、简单易用的数据库开发工具,比如 Access,可以最高效率将软件开发出来。 2.1.2采用 MyEclipse 开发平台 MyEclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是
16、, MyEclipse 附带了一个标准的插件集,包括 Java 开发工具( Java Development Tools, JDT)。 MyEclipse 最初是由 IBM 公司开发的替代商业软件 Visual Age for Java 的下一代 IDE 开发环境, 2001 年 11 月贡献给开源社区,现在它由非营利软件供应商联盟 MyEclipse 基金会( MyEclipse Foundation)管理。 2003 年, MyEclipse 3.0 选择 OSGi 服务平台规范为运行时架构。 2007 年 6 月,稳定版 3.3 发布。 2008 年 6 月发布代号为 Ganymede
17、的 3.4 版。 MyEclipse 是著名的跨平台的自由集成开发 环境( IDE)。最初主要用来 Java 语言开发,但是目前亦有人通过插件使其作为其他计算机语言比如 C+和 Python 的开发工具。MyEclipse 的本身只是一个框架平台,但是众多插件的支持使得 MyEclipse 拥有其他功能相对固定的 IDE软件很难具有的灵活性。许多软件开发商以 MyEclipse为框架开发自己的 IDE。 MyEclipse 最初由 OTI 和 IBM 两家公司的 IDE产品开发组创建,起始于 1999年 4月。IBM 提供了最初的 MyEclipse 代码基础,包括 Platform、 JDT
18、 和 PDE。目前由 IBM 牵头,围绕着 MyEclipse 项目已经发展成为了一个庞大的 MyEclipse 联盟,有 150 多家软件公司参与到 MyEclipse 项目中,其中包括 Borland、 Rational Software、 Red Hat 及 Sybase 等。MyEclipse 是一个开发源码项目,它其实是 Visual Age for Java 的替代品,其界面跟先前的Visual Age for Java 差不多,但由于其开放源码,任何人都可以免费得到,并可以在此基础上开发各自的插件,因此越来越受人们关注。近期还有包括 Oracle 在内的许多大 公司也纷6 纷加入
19、了该项目,并宣称 MyEclipse 将来能成为可进行任何语言开发的 IDE 集大成者,使用者只需下载各种语言的插件即可。 虽然大多数用户很乐于将 MyEclipse 当作 Java IDE 来使用,但 MyEclipse 的目标不仅限于此。 MyEclipse 还包括插件开发环境( Plug-in Development Environment, PDE),这个组件主要针对希望扩展 MyEclipse 的软件开发人员,因为它允许他们构建与 MyEclipse 环境无缝集成的工具。由于 MyEclipse 中的每样东西都 是插件,对于给 MyEclipse 提供插件,以及给用户提供一致和统一的
20、集成开发环境而言,所有工具开发人员都具有同等的发挥场所。 基于 MyEclipse 的应用程序的突出例子是 IBM 的 WebSphere Studio Workbench,它构成了 IBM Java 开发工具系列的基础。例如, WebSphere Studio Application Developer 添加了对 JSP、 servlet、 EJB、 XML、 Web 服务和数据库访问的支持。 MyEclipse 的主要组成 :MyEclipse 是一个开放源代码的软件开发项目,专注于为高度集成的工具开发提供一个全功能的、具有商业品质的工业平台。它主要由 MyEclipse 项目、MyEcl
21、ipse 工具项目和 MyEclipse 技术项目三个项目组成,具体包括四个部分组成 MyEclipse Platform、 JDT、 CDT 和 PDE.JDT 支持 Java 开发、 CDT 支持 C 开发、 PDE 用来支持插件开发, MyEclipse Platform 则是一个开放的可扩展 IDE,提供了一个通用的开发平台。它提供建造块和构造并运行集成软件开发工具的基础。 MyEclipse Platform 允许工具建造者独立开发与他人工具无缝集成的工具从而无 须分辨一个工具功能在哪里结束,而另一个工具功能在哪里开始 MyEclipse SDK(软件开发者包)是 MyEclipse
22、 Platform、 JDT 和 PDE所生产的组件合并,它们可以一次下载。这些部分在一起提供了一个具有丰富特性的开发环境,允许开发者有效地建造可以无缝集成到 MyEclipse Platform中的工具。 MyEclipse SDK由 MyEclipse 项目生产的工具和来自其它开放源代码的第三方软件组合而成。 MyEclipse项目生产的软件以 CPL 发布,第三方组件有各自自身的许可协议。 2.1.3采用 SQL server 2008数据库 SQL Server 2008 在 Microsoft 的数据平台上发布,可以组织管理任何数据。可以将结构化、半结构化和非结构化文档的数据直接存储
23、到数据库中。可以对数据进行查询、搜索、同步、报告和分析之类的操作。数据可以存储在各种设备上,从数据中心最大的服务器一直到桌面计算机和移动设备,它都可以控制数据而不用管数据存储在哪里。 SQL Server 2008 允许使用 Microsoft .NET 和 Visual Studio 开发的 自定义应用程序中使用数据,在面向服务的架构( SOA)和通过 Microsoft BizTalk Server 进行的业务流程中使用数据。信息工作人员可以通过日常使用的工具直接访问数据。 2.2 经济可行性研究 (1)小型超市管理系统开发成本低 7 小型超市管理系统开发需要的工具都是开源 、免费 的,
24、开发工具几乎不需要什么成本。唯一的成本就是系统开发的技术人员,二三个 人 甚至一个人在高效率状态下在短时间内就可以开发出满足小型超市管理系统需求的软件。 (2)新系统带来新效益 管理系统是一个信息化、智能化和先进管理理念的集合体。而管理是一个动态过程,在其运行过程中要采取多项措施。所以在管理中获得经济效益是一个综合效益,要对它进行直接定量的分析是比较困难的。一般新系统带来的经济效益是简介的,其最主要的表现就是减少了超市管理费用和人力开支。而其它一些繁琐的商品都通过新系统来加以分析解决,不仅节省了大量的时间,还为小型超市的各项决策提供了宝贵的资料,可以带来巨大的经济效益。 2.3 操 作可行性研
25、究 本系统采用基于 Windows 的图形用户界面,而该系统是大家熟悉的操作系统,对于那些有一般的计算机知识的人员就可以轻松上手。而整个超市管理系统采用最友好的交互界面,简介明了,不需要对数据库进行深入的了解。由此,该系统的操作是可行的,有必要开发该系统。综合以上三方面,该系统具有很高的开发可行性,无论是从技术上或者经 济上还是操作上。 8 3 系统需求分析 3.1 超市基本业务分析 3.1.1进货业务 进货管理是企业生产经营活动中及其重要的一环,它关系到产品质量能否得到保证,生产是否能够顺利进行,采购成本能否得到有效控制等问题。企业现代管理理念中对企业的进货管理提出新的要求;企业进货时对供货
26、商的选择更见慎重,双方不再是讨价还价的买卖关系,而是一种相互依存的合作伙伴关系,并且还需要认识到企业产品质量要从采购抓起,这就关系到供方的供货、服务质量。下面是进货业务程序的主要内容: (1)供货商的情况调查:在实施采购之前,超市首先就要对市场上各大商品供货商进行详细的调查,了解公司的具体情况,评定企业的信誉级别和公司 的市场口碑,做到准确无误,采购顺利。 (2)采购计划的编制:超市根据自身的资金条件和销售状况,综合分析市场规律,拟定采购计划表。 (3)实施进货计划:根据供货商档案及评审结果,选定供货商;生成订货单给选定的供货商;双方就价格、数量、质量等方面洽谈磋商,直至签订合同;跟踪合同执行
27、,安排供货进度和货物运输,做好验收入库工作。 3.1.2 库存业务 库存管理是指在上产经营中为销售和耗用而存储的各种资产。企业存货不当都会增加不必要的费用:存货过多将导致物资的积压、存储费用增加、流动资金周转不利,并且过量的库存会掩盖管 理不善的问题。存货不足则影响企业的正常销售活动。库存管理的目标是需求最佳存货数量,使库存的成本总额最小化。其主要业务如下: (1)产品入库、出库、盘库等日常处理。 (2)科学合理地确定某库存物资的库存控制参数。如:最佳订货批量、最大库存量、最佳缺货量、最佳订购周期等,进行严格的库存控制工作。 (3)汇总统计各类库存数据,反应和监督储备资金占用及采购资金使用情况
28、。 3.1.3销售业务 销售对一个企业的生存和发展是至关重要的,它不再是传统意义上的“卖东西”,它对外关系到企业产品、服务和企业形象等多方面因素,对内涉及到销售、库存、财务等信息。此外信息化的高速发展为企业的销售工作提出了新的挑战,封闭意味着落后,超市要9 抓住时机,引入现代化的销售管理模式,实施企业的信息化、智能化销售管理,才能使超市在激烈的市场竞争中立于不败之地。 3.1.4传统小型 超市 需要解决的 问题 小型超市的发展至少必需要解决以下两个问题: (1)物流管理方式落后,很难根据 销售、库存情况,及时进行配货、补货、 退货、 调拨。 小型超市在物流管理方面仍使用传统的人工管理模式,浪费
29、人力资源,效率低,准确 率低。有些商品紧缺,顾客要排队购买或商品供不应求,使顾客大为不满,还有一些商品长期积压,损坏严重,造成重大经济损失 ,此类问题屡屡发生,得不到根本性的解决。 (2)财务,账目管理混乱,透明度低。 小型超市在财务管理方面,仍使用传统的人工记账模式,效率低,容易出错,不能进行有效的统计,不能及时地高效率地针对买卖情况制定行之有效的经营决策,容易在账目上纠缠不清,投入大量精力在算账上,另一方面却错失销售赚钱的良机。 3.2 系统功能 需求 基于超市基本业务分析,和小型超市必须解决的两大难题,针对性地制定出所要设计小型超市管理系统所需要的系统功能,如下七点: (1)设计软件提供
30、用户登陆界面,为用户提供账 号 密码 管理工具 ,能设置用户权限,不同权限的用户付给 不同的操作权利 ,具体为添加用户、删除用户、修改用户名、密码、权限 。 (2)设计软件将对进货产品进行管理,对进货清单进行录入 、修改、查询 和统计,也提供退货功能,对退货清单进行录入 和查询 。 (3)设计软件将提供销售功能, 按商品名或者商品编号查询进行销售,提供付款、找零功能,并 对销售清单进行录入、查询和统计,并能打印相关信息。 (4)设计软件将能对库存情况进行 修改 操作和查询 操作 , 能设置库存商品单价,能对库存商品总值进行统计, 并能打印相关信息。 (5)设计软件能对收支盈亏情况进行简单的统计
31、和查询。 (6)设计软件能对超市员工信息进行 管理,具体为 添加 员工信息 、删除 员工信息 、修改 员工信息 操作。 (6)设计软件能对供货商信息进行管理,具体为添加供货商信息、删除供货商信息、修改供货商信息操作。 (7)设计软件能实现系统数据的初始化,数据库的备份和还原。 10 3.3 性能需 求 (1)开发 运行 系统 的硬件、软件需 求 硬件平台:硬盘空间: 20G 以上; 内存: 256M 以上; CPU: PIII500 以上; 操作系统: Windows 2000/windows XP/windows 7 编译环境: JDK5.0 ; 开发工具 :MyEclipse10;SQL server 2008 (2)时间特性 软件的响应时间、更新处理时间、数据转换时间、传输时间除 了和 软件本身的逻辑关系有一定的关系外,数据的流量、 硬件 传输速度等都会对其有一定的影响,就软件本身而言业务逻辑会做到简洁明了以减少用户等待时间。 一般情况下,系统软件从启动到进入系统登录界面的时间正常情况下应少于 5 秒,录入并更新数据的时间正常情况下少于 2 秒。 (3)适应性 本软件要求以 JAVA 语言来开发,所以本软件具有 JAVA 语言的所有的优点,跨平台、易升级、易扩展等,相对与其他的语言在操作方式、运行环境、与其它软件的接口以及开发计划等发生变化时,会具有更强的适应能力。