版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、2008届毕业生毕业论文题 目: 超市进销存系统的设计和实现 院系名称: 信息科学与工程学院 专业班级: 计算机科学与技术04级7班 学生姓名: *8 学 号: 2004211014 指导教师: * 教师职称: 讲师 2008 年 6 月 12 日摘 要当前, 随着经济的全球化以及中国经济改革的逐渐深化,使得国内中小企业都面临着巨大的挑战,零售业也面临着越来越激烈的竞争。传统的超市进销存业务在管理时工作量大、费时费力、效率低下,为了方便超市的管理,引入了超市进销存系统。通过分析超市运营的基本业务和管理的总体需求,设计了一个超市进销存系统。首先简要分析了超市进销存系统的现状和发展,并介绍了该系统
2、研究的目的和意义,详细论述了.net三层架构模式,在分析了这种模式的基础上完成了超市进销存系统的结构设计和功能设计。同时出于应用程序的开发部署和业务逻辑的架构的考虑,采用三层设计模式,即:数据层、业务逻辑层、用户层。其次,在超市进销存系统的功能模块及数据库方面对该系统进行了具体设计,并成功地解决了超市的采购、销售和库存管理问题,实现了超市进销存管理系统的基本功能。最后,对该超市进销存系统进行展望和总结。关键词: 超市进销存 三层模式 数据库 title design and implementation of supermarket invoicing system abstractat pr
3、esent, with the economic globalization and chinas economic reforms gradually deepen, making domestic smes are faced with enormous challenges, and the retail industry is also faced with increasingly fierce competition .in the management of the traditional supermarket invoicing business ,it is workloa
4、d, time- consuming effort, inefficiency, and for conveniently manage of the supermarket, i introduce a supermarket invoicing system. through analysis the supermarket operators basic operations and the overall demand for its management, i design a supermarket invoicing system. first, briefly analysis
5、 the status and the development of supermarket invoicing system, and introduce the purpose and significance of the system, and discuss the .net three layer model in detail. on the basis of analysis this model i complete the structural design and functional design of the supermarket invoicing. at the
6、 same time for the development of application and consideration of business logic framework, i adopt the three-tier design, namely: the data layer, business logic layer, user layer. secondly, i do specific design on function modules and database of the supermarket invoicing system, and i successfull
7、y resolve the management issue of supermarket purchases, sales and inventory, and i realize the basic functions of the supermarket invoicing system. finally, outlook and summarize the supermarket invoicing system.keywords supermarket invoicing three layer mode database 目 次1 引言11.1 超市进销存系统的现状和发展11.2
8、.net的出现11.3 论文的主要工作和研究思路22 超市进销存系统的需求分析42.1 超市进销存系统功能需求42.2 超市进销存系统功能模块分析42.3 超市进销存的系统流程分析52.4 超市进销存系统的软硬件需求62.5 超市进销存系统的数据需求63 超市进销存系统的概要设计83.1 超市进销存系统的三层模式描述83.1.1 超市进销存系统数据访问层的描述83.1.2 超市进销存系统业务逻辑层的描述93.1.3 超市进销存系统界面表现层的描述93.2 基础信息模块设计93.3 进货管理模块设计103.4 销售管理模块设计103.5 退货管理模块设计113.6 仓库管理模块设计123.7 系
9、统管理模块设计124 超市进销存系统数据库设计144.1 数据库概念设计144.2 数据库逻辑设计165超市进销存系统的详细设计与实现225.1 超市进销存系统数据访问层225.2 超市进销存系统业务逻辑层235.3 超市进销存系统界面表现层245.3.1 进货管理模块的实现245.3.2 销售管理模块的实现255.3.3 退货管理模块的实现275.3.4 仓库管理模块的实现275.3.5 基础信息模块的实现285.3.6 系统管理模块的实现29结 论32致 谢33参 考 文 献341 引言1.1 超市进销存系统的现状和发展在实际的超市经营过程中,由于超市货品种类繁多,价格不一,对商品信息进行
10、手工管理时,工作量大、重复工作多、费时费力、效率低下。除此之外,做统计报表时又要将一年中所有的进货量和出售量进行总结、归纳,再将结果重新统计,很容易出现不易察觉的错误,带来经济损失,同时花费的时间更长,重复的工作更多。鉴于此,我用.net编写了一套对超市商品进销存进行综合管理的系统。通过该系统能及时了解各商品的采购、销售及库存等情况。随着超市商品的大量增加,其管理难度越来越大。在计算机技术飞速发展的今天将计算机这一信息处理利器应用于超市的日常管理已是势所必然。这为超市管理带来前所未有的改变,同时为超市带来意想不到的经济效益和社会效益,这主要体现在以下几个方面:(1)极大的提高了超市工作人员的工
11、作效率,避免了以往进销存流程繁琐、杂乱、周期长的弊端。(2)超市管理实现了操作自动化和信息电子化,全面提高了超市的管理水平。(3)基于超市管理的全面自动化,可以大大减少入库管理、出库管理及库存管理中的漏洞,可以节约大量管理开支,增加超市的收入。1.2 .net的出现2002年2月,microsoft 推出了.net,.net的出现也代表了windows平台的软件开发将进入一个新的领域。 .net对于windows平台上开发工具厂商有着深远的影响,因为.net对于windows平台来说是有史以来变动最大的一次,microsoft第一次把windows变成了一个虚拟执行环境,使用soap/web
12、service 技术把windows和各种移动和电子装置整合在一起,提供下一代的整合虚拟数字世界。microsoft称.net的战略目标是:任何人在任何地方,使用任何设备都可以打开自己熟悉的操作界面。xml,soap,web service将为microsoft实现这个战略提供有力的技术支持。因此.net的侧重点从连接到互联网的单一网站或设备上,转移到计算机,移动设备和服务群组上,使其通力合作,提供更广泛更丰富的解决方案。用户将能够控制信息的传送方式、时间和内容。计算机、设备和服务将能够相辅相成,从而提供丰富的服务,而不是孤立的。1.2.1 .net的体系结构整个microsoft .net体
13、系由以下三个部分组成:(1) .net框架,包括公用语言运行库(common language runtime)、系统类库(class libraries)、asp.net。(2)web services。(3).net企业服务,包括biz talk server 2000、exchange 2000 server、host integration server 2000、application center 2000、sql server 2000等。.net体系结构如图1.1所示。user interfaceweb service基于xml的数据交换.net基础类库公用语言运行库commo
14、n language runtime图1.1 .net体系结构1.2.2 数据库访问技术ado.net数据存取是现代软件开发中的一项主要工作,无疑它在.net框架中也占有很重要的地位。ado. net是microsoft在.net中对数据存取问题的解决方案,也是.net开发平台的核心服务之一。在.net框架中,ado.net是一套类,它为.net开发人员提供了数据访问服务,用以创建分布式的数据共享应用程序。虽然它的名字非常类似于以前的activex data object(ado),但实际上,ado.net是microsoft的universal data access(通用数据访问)战略的最
15、新成果,它为sql server,oledb和xml数据源等各种类型数据提供了一致的数据访问。数据共享客户应用程序可以使用ado.net,连接这些数据源,并操作数据。ado.net支持不同的开发需求,例如前端数据库客户和由应用程序、工具、语言或internet浏览器适用的中间商业对象等。1.3 论文的主要工作和研究思路本文是依据超市的管理流程,在熟悉管理系统的相关知识的基础上分析超市运营的基本业务和其管理的总体需求,结合自己的构思并运用.net技术对超市进销存系统进行分析和设计,提出解决方案。论文首先对超市进销存系统进行需求分析,并根据数据特点提出自己的解决方案,然后论文进入系统概要设计和详细
16、设计部分,通过对三层开发模式的架构分析,划分界面表现层,业务逻辑层和数据访问层。在概要设计的基础上结合.net技术,重点解决各层的类和接口的设计。在数据库设计阶段,主要解决各种实体、e-r图和表的设计。在详细设计阶段,主要解决各个模块的设计,然后完成界面设计,最后进行系统的测试和完善。研究思路如图1.2所示。.net技术规范与体系结构研究超市进销存系统的需求分析.net应用模型和开发方法研究文献资料搜集 基础理论研究系统概要设计系统数据库设计系统详细设计完成论文系统总结系统开发图1.2 研究思路2 超市进销存系统的需求分析超市的日常业务经营活动主要包括基础信息、进货管理、销售管理、仓库管理、退
17、货管理和系统管理等几个方面。因此,如何处理好这几者之间的关系是设计超市进销存管理系统最为关键的部分。2.1 超市进销存系统功能需求本系统开发的总体目标是建立一个能够对超市内商品流动进行监控,即在商品采购、销售、库存等过程中进行监督与控制的进销存管理系统。根据对部分超市管理日常工作的调研结果及其管理的总体需求的分析,系统应具备以下功能: (1)采购员采购商品后,及时录入商品信息数据,在数据库中进行数据更新。(2)商品入库时,生成商品进货单,及时更新数据库。(3)在收银处,随时录入卖出商品信息,如名称、数量、单价等,及时更新数据库数据。(4)从仓库提货时,生成提货报告,并提供该商品的库存信息,剩余
18、信息。(5)对往来单位信息进行综合管理,使管理者可以方便、快捷的得到往来客户的信息。(6)某仓库的货物过多时,可以将该仓库的货物转存到其他仓库,即仓库调拨。并记录调拨的商品,数量,仓库。2.2 超市进销存系统功能模块分析根据超市运营的基本业务和管理的总体需求,进行需求分析,并根据分析绘出系统功能模块图,如图2.1所示。超市进销存系统基础信息模块进货管理模块销售管理模块退货管理模块仓库管理模块往来单位信息添加进货单进货单管理备份数据库查询统计商品信息管理添加销售单销售单管理修改密码仓库调拨仓库设置查询统计添加退货单退货单管理查询统计系统管理模块管理员设置商品分类设置库存报警图2.1 超市进销存系
19、统功能模块2.3 超市进销存的系统流程分析根据需求分析,绘出系统流程如图2.2所示。用户登录系统首页基础信息管理是否成功yn进货管理销售管理仓库管理退货管理系统管理图 2.2 超市进销存系统流程2.4 超市进销存系统的软硬件需求(1)硬件需求cpu: piii 900 mhz内存:256mb(2)软件需求由于大多数企业内部使用的计算机平台都是基于windows环境的。为降低系统成本,应最大程度地利用现有的资源、兼容现有的环境,使用下面的开发环境:主机平台:windows 2000/xp/2003;开发工具:visual studio 2005数据库服务器:sql server 2000;2.5
20、 超市进销存系统的数据需求超市进销存系统所管理的数据和数据结构大致如下:(1)系统账号表包括的数据项有:用户id、登录名、用户姓名、密码、部门、电话。(2)部门信息表包括的数据项有:部门id、部门名。(3)往来单位表包括的数据项有:公司id、公司名、联系人、电话、邮编、传真、联系人手机、联系人email、联系人职务、公司网站、数字码、拼音码、地址、备注、类别、信誉程度、区域、是否删除、添加时间。(4)字典维护表包括的数据项有:维护id、类别、字段名、字段值、作废。(5)商品分类表包括的数据项有:类别id、类别序号、类别名称、序号列、上一个序号、序号深度、顺序、类别标识。(6)商品表包括的数据项
21、有:商品id、数字码、拼音码、商品名、商品类别、商品默认价格、规格、单位、商品描述、录入人、添加时间、作废、库存量、仓库。(7)出入库单据表包括的数据项有:出入库单id、出入库单号、出入库单位、确认、审核、录入人、确认人、审核人、出入库时间、确认时间、审核时间、类别、作废、部门、备注。(8)出入库明细表包括的数据项有:出入库明细定单id、出入库单id、商品id、商品价格、出入库数量、条形码、添加时间、类别、作废、标记、备注。(9)仓库表包括的数据项有:仓库编号、仓库名称。(10)商品调拨表包括的数据项有:调拨编号、调拨商品、调入仓库、调出仓库、调拨数量、调拨日期。(11)数据库备份表包括的数据
22、项有:备份id、备份名称、备份时间。3 超市进销存系统的概要设计本文采用分层设计思想,将整个系统划分为:(1)数据访问层:专门负责对数据的访问;(2)业务逻辑层:负责业务逻辑;业务逻辑层封装了数据传输和一些具体算法,用来完成表示层的请求,接受从表示层传递的参数,封装表示层需要的、从数据层返回的数据以及建立ado.net中关系数据的完整性,主键约束。(3)界面表现层:与用户进行交互,负责将数据和处理结果呈现的用户。本系统的三层结构如图3.1所示。界面表现层数据访问层实体类 db 用户业务逻辑层实体类图3.1 超市进销存系统的三层结构3.1 超市进销存系统的三层模式描述3.1.1 超市进销存系统数
23、据访问层的描述数据库是系统的最底层,它存储系统的所有数据。数据访问层建立在数据库之上,应用程序通过该层访问数据库。数据访问层一般有数据库的选择,添加,更新和删除等操作,同时还为业务逻辑层提供访问数据库的接口和函数等。该层直接与数据库相关联,同时又为业务逻辑层服务,所以数据访问层设计的好坏关系到整个系统的成败。3.1.2 超市进销存系统业务逻辑层的描述 业务逻辑层又被称为中间层、组件层。业务逻辑层封装了数据传输和一些具体算法,用来完成表示层的请求,接受从表示层传递的参数,封装表示层需要的、从数据层返回的数据以及建立ado.net中关系数据的完整性,主键外键约束等。业务逻辑层负责接收浏览器传来的请
24、求并将请求传给数据层,同时将请求处理结果发给浏览器。它由web表单、xml web服务和组件服务组成。其中web表单是asp.net应用程序的核心所在,它是向客户呈现数据和信息的基础,也是响应和处理客户与显示的web表单交互生成的信息和数据的基础。3.1.3 超市进销存系统界面表现层的描述表示层是三层开发模式的最高层,它一般有web页面组成,为用户提供了界面接口。如系统首页default.aspx及其源文件default.aspx.cs,系统登录页面login.aspx及其源文件login.aspx.cs。 3.2 基础信息模块设计从系统功能描述来看,基础信息模块由商品分类设置、往来单位管理、
25、商品信息管理三个子模块组成。用户可以添加往来单位信息和商品信息,并可按照类别、信誉度、区域对往来单位信息进行查询,也可按照商品分类对商品信息进行查询。该功能模块的结构如图3.2所示。数据访问层界面表示层基础信息管理商品分类设置往来单位信息商品信息管理业务逻辑层数据访问层数据库图 3.2 基础信息模块结构3.3 进货管理模块设计从系统功能描述来看,进货模块由添加进货单,进货单管理,查询统计三个子模块组成。用户可按往来单位、单据号、商品名称、条形码和添加时间,对进货单进行查询,也可对进货单进行统计查询。每张单据可以包含多种商品,同时计算出该单据中所进商品的总价格。该功能模块的结构如图3.3所示。数
26、据访问层界面表示层进货管理添加进货单进货单管理查询统计业务逻辑层数据访问层数据库图 3.3 进货管理模块结构3.4 销售管理模块设计从系统功能描述来看,销售模块由添加销售单,销售单管理,查询统计三个子模块组成。用户可按往来单位、单据号、商品名称、条形码和添加时间,对销售单进行查询,也可对销售单进行统计查询。每张单据对应多种商品,同时计算出该单据中销售商品的总价格。该功能模块的结构如图3.4所示。数据访问层界面表示层销售管理添加销售单销售单管理查询统计业务逻辑层数据访问层数据库图 3.4 销售管理模块结构3.5 退货管理模块设计从系统功能描述来看,退货模块由添加退货单,退货单管理,查询统计三个子
27、模块组成。用户可按往来单位、单据号、商品名称、条形码和添加时间,对退货单进行查询,也可对退货单进行统计查询。该功能模块的结构如图3.5所示。注意:退货单中的商品必须是已经存在的商品。数据访问层界面表示层退货管理添加退货单退货单管理查询统计业务逻辑层数据访问层数据库图 3.5 退货管理模块结构3.6 仓库管理模块设计从系统功能描述来看,仓库模块由仓库调拨、仓库设置和库存报警三个子模块组成。用户可以使用仓库调拨功能在各个仓库之间调拨商品,使用仓库设置功能对仓库进行添加、删除和修改。如果当前库存量小于等于1时,则在库存报警页面显示该商品的信息,以提示用户及时进货。该功能模块的结构如图3.6所示。数据
28、访问层界面表示层仓库管理仓库调拨仓库设置库存报警业务逻辑层数据访问层数据库图 3.6 仓库管理模块结构3.7 系统管理模块设计从系统功能描述来看,系统管理模块由备份数据库、管理员设置、修改密码三个子模块组成。登录用户可以对数据库进行备份,添加新的管理员,并能够修改自己的密码。该功能模块的结构如图3.7所示。数据访问层界面表示层系统管理备份数据库管理员设置修改密码业务逻辑层数据访问层数据库图 3.7 系统管理模块结构4 超市进销存系统数据库设计4.1 数据库概念设计概念结构设计是整个数据库设计的关键。概念设计是对现实世界的一种抽象,抽取所关心的共同特性,忽略非本质的细节,并把这些特性用各种概念精
29、确的加以描述,这些概念组成了某种模型。描述概念模型的有力工具是e-r模型,即实体-联系模型。本系统根据对数据库的需求分析设计出11个实体:用户信息实体、部门信息实体、往来单位实体、字典维护实体、商品分类实体、商品实体、出入库单据实体、出入库明细实体、仓库实体、仓库调拨实体、数据库备份实体。限于篇幅,仅列出主要实体和其e-r图及其关系描述:(1)用户信息实体的描述,如图4.1所示。用户信息联系电话用户账号用户id用户密码il用户部门用户姓名图4.1 用户信息实体(2)往来单位实体的描述,如图4.2所示。往来单位数字码公司名公司id联系人电话类别信誉程度添加时间图4.2 往来单位实体(3)商品信息
30、实体的描述,如图4.3所示。 商品信息商品价格数字码商品id库存量仓库商品名商品类别添加时间图4.3 商品信息实体(4)出入库单据实体的描述,如图4.4所示。出入库单据审核人出入库单号出入库id确认确认人审核出入库时间类别图4.4 出入库单据实体(5)仓库调拨实体的描述,如图4.5所示。仓库调拨调拨日期调拨商品调拨编号调入仓库调拨数量调出仓库图4.5 仓库调拨实体(6)出入库明细实体的描述,如图4.6所示。出入库明细添加时间出入库单号出入库明细id商品id条形码商品价格出入库数量类别图4.6 出入库明细实体(7)本系统的e-r 图根据以上需求分析,本系统部分e-r图(实体-关系图),如图4.7
31、所示。往来单位仓库商品mm1nn存储管理发表进货或销售n进货或销售单据调拨发表用户mn图4.7 超市进销存系统e-r 图4.2 数据库逻辑设计(1) 用户信息表(shuser)存放用户登录信息,如表4.1所示。表4.1 用户信息表字段名称字段描述数据类型长度允许为空备注id用户idint4否pkuserid用户账号nvarchar50passwd用户密码nvarchar50usename用户姓名nvarchar50dept用户部门int4tel联系电话nvarchar50(2) 部门信息表(shdept)存放部门信息,如表4.2所示。表4.2 部门信息表字段名称字段描述数据类型长度允许为空备注
32、id部门idint4否pkdeptname部门名字nvarchar50(3) 往来单位表(shcorp)存放往来单位信息,如表4.3所示。表4.3 往来单位表字段名称字段描述数据类型长度允许为空备注id公司idint4否pkcorpname公司名nvarchar50linkman联系人nvarchar50telephone电话nvarchar50postcode邮编nvarchar50fax传真nvarchar50handset联系人手机nvarchar50email联系人mailnvarchar2business联系人职务nvarchar16web公司网站nvarchar20numcode数
33、字码nvarchar16dspt备注varchar500corpkind类别int4creditlevel信誉程度int4corparea区域int4iswas删除int4addtime添加时间datetime16(4) 字典维护表(shdict)是往来单位的辅助信息,提供往来单位表中某些字段的具体信息。如表4.4所示。表4.4字典维护表字段名称字段描述数据类型长度允许为空备注id维护idint4否pkkind类别nvarchar50wordname字段名nvarchar50intvalue字段值nvarchar50strvalue字段值int4iswas作废nvarchar50(5) 商品分
34、类表(shclass)存放商品的分类信息,如表4.5所示。表4.5 商品分类表字段名称字段描述数据类型长度允许为空备注id类别idint4否pkclassid类别序号nvarchar50否classname类别名称nvarchar50classlist序号列nvarchar50否classpre上一个序号nvarchar50否pkclasstj序号深度int4否classorder顺序int4classkind类别标识int4否storekind仓库int4否(6) 商品信息表(shproduct)存放商品的所有信息,如表4.6所示。表4.6 商品信息表字段名称字段描述数据类型长度允许为空备注
35、id商品idint4否pknumcode数字码nvarchar30pycode拼音码nvarchar4proname商品名nvarchar4proclass商品类别int8proprice商品价格money8spes规格nvarchar500unit单位nvarchar30prodes商品描述ntext4opstf录入人int4addtime添加时间datetime8iswas作废int8stroecount库存量int16storeid仓库int16(7) 出入库单据表(shbill)存放出入库的单据,如表4.7所示。表4.7 出入库单据表字段名称字段描述数据类型长度允许为空备注id出入库i
36、dint4否pkbillno出入库单号nvarchar50incorp出入库单位int4issure确认int4ischeck审核int4instf入库人int4surestf确认人int4checkstf审核人int4intm出入库时间datetime50suretm确认时间datetime4checktm审核时间datetime4kind类别int4iswas作废int4storekind仓库int4dspt备注nvarchar50(8) 出入库明细表(shbilllist)存放出入库单据详情,如表4.8所示。表4.8 出入库明细表字段名称字段描述数据类型长度允许为空备注id出入库单idi
37、nt4否pkbillid出入库单号int4proid商品idint4proprice商品价格int4mainbarcode条形码nvarchar50incount出入库数量int4addtime添加时间datetime8kind类别int4iswas作废int4flag标记int4dspt备注nvarchar500(9) 仓库表(shstore)存放仓库信息,如表4.9所示。表4.9仓库表字段名称字段描述数据类型长度允许为空备注storeid仓库编号int4否pkstoretype仓库名称char10(10) 仓库调拨表(shstoremix)存放商品调拨信息,如表4.10所示。表4.10仓库
38、调拨表字段名称字段描述数据类型长度允许为空备注mixid调拨编号int4否pkproductid调拨商品int4storeto调入仓库nvarchar50storefrom调出仓库nvarchar50mixcount调拨数量int4mixdate调拨日期datetime8(11) 备份信息表(shdataback)存放数据库备份信息,如表4.11所示。表4.11备份信息表字段名称字段描述数据类型长度允许为空备注id信息idint4否pkdataname备份名称nvarchar50backtime备份时间datatime85 超市进销存系统的详细设计与实现客户端浏览器使用基于服务器的程序提供的一
39、组服务,这些服务器程序的最高层公开,客户端只与最高层交互,而无法直接了解任何较低的层。在asp.net程序中,三层架构的具体实现可能进行多种形式的扩展,在较复杂的asp.net程序中,可能将业务层中重要的对象和方法封装到统一的类库中,这些类库以dll形式提供给系统,其内部也是分层的结构。三层结构组织如图5.1所示。图5.1 三层结构组织5.1 超市进销存系统数据访问层数据访问层的任务就是打开连接,然后创建命令对象,给命令对象的commandtext属性设置值,可以是存储过程名字,也可以sql语句。然后就调用执行命令的方法,得到结果后返回。本系统将数据库访问的代码封装到了一个类中,这个类是dbh
40、elpersql.cs,类中的方法都是静态的,可以直接调用。它专门负责访问数据库,这样本系统的各模块的实现只需要调用这个类,就可以取得数据库中的数据。系统中每一个模块的实现都需要在da层中做相应的声明,例如添加进货单中,当采购员采购回商品时,需要将数据提交给进货单类,这一个业务需要在da层中声明一个方法insertdata(),然后在业务逻辑层中调用da层中的这个方法。本系统da层中主要的处理数据库的类如图5.2所示。图5.2 da层中的类5.2 超市进销存系统业务逻辑层业务逻辑层封装了数据传输和一些具体算法,用来完成表示层的请求,接受从表示层传递的参数,封装表示层需要的、从数据层返回的数据以
41、及建立ado.net中关系数据的完整性,主外键约束等。如进货管理模块,当需要将采购的商品数据提交给进货单类的时候,就需要在业务层中调用相关方法,业务层再通过da层中的insertdata()这个方法进行操作数据库,就可以完成商品存库并生成进货单这一过程。本系统主要的业务逻辑层类如图5.3所示。图5.3 业务逻辑层类5.3 超市进销存系统界面表现层本系统用的界面表现层是web窗体,通过它来负责和管理者的交互。在本层中运用visual studio 2005提供的各类控件,来实现形式各样的显示效果,结合dreamweaver强大的美化功能,弥补了studio在界面上的操作不足。在本系统中,进货管理
42、、销售管理、退货管理使用的是同一个页面,通过参数billtype来判断到底是哪个页面、哪个单据类型,从而进行相应操作。因此以下对这三个模块的相同部分只详细分析了一个。5.3.1 进货管理模块的实现该模块包含三个页面:instorelist.aspx(进货单管理),instore.aspx(添加进货单),instorestat.aspx(查询统计)。本文只对instorelist.aspx页面进行了详细说明。在该模块中,instorelist.aspx页面主要是用来显示进货单据列表,同时可以根据不同条件来查询进货单据信息。也可以根据需求进入相应功能的页面。根据从相应页面传过来的参数billtyp
43、e,判断该页面是进货页面,销售页面还是退货页面。进货单管理页面instorelist.aspx如图5.4所示。图5.4 进货单管理页面在实现过程中,主要用gridview控件来显示单据列表。在控件中加入多个模板列,分别对应要显示的字段信息。将单据号和往来单位两个模板列中加入hyperlink控件,对其分别命名为:hlbillno和hlcorpname,使用户点击这两列的数据时可以转到相应的功能的页面上。hlbillno控件的数据绑定是通过代码实现动态绑定,代码如下:hlbillno.text = dvshbilldata.billno_field.tostring();hlbillno.nav
44、igateurl=string.format(instore.aspx?billtype=0&billid=1,(int)this.billtype,dvshbilldata.id_field.tostring();hlcorpname控件则直接在前台页面中对其实现数据绑定。text的自定义绑定表达式:databinder.eval(container.dataitem,shbilldata.corpname_field ) navigateurl自定义绑定表达式:databinder.eval(container.dataitem,shbilldata.incorp_field ,corpe
45、dit.aspx?id=0);5.3.2 销售管理模块的实现该模块包含三个页面:instorelist.aspx(销售单管理),instore.aspx(添加销售单),instorestat.aspx(查询统计)。本文在该部分只对instore.aspx页面进行了详细说明。在该模块中,instore.aspx页面主要对销售单据进行添加、修改和移除。在添加销售单时,首先调用searchstorecount()函数返回商品的库存量,和将要销售的数量进行比较,如果比较结果小于0则提示用户库存不足,并显示出剩余库存量;如果比较结果大于等于0则添加销售单成功,同时把该条单据的iswas字段设置为0。点击
46、“移除”按钮,将调用setwasbyid()函数把iswas字段设置为1,表示该条数据已作废,将不会再列表中显示。添加销售单页面instore.aspx如图5.5所示。图5.5 添加销售单页面单击往来单位的选择按钮,将弹出往来单位信息列表selcorp.aspx,往来单位选择页面selcorp.aspx如图5.6所示。图5.6 往来单位选择页面选择了单位以后单位的信息将自动添加到该页面的相应文本框中,从而减少了用户的输入。商品的选择按钮和往来单位的选择按钮功能相似,在此不再赘述。5.3.3 退货管理模块的实现该模块包含三个页面:instorelist.aspx(退货单管理),outstore.
47、aspx(添加退货单),instorestat.aspx(查询统计)。本文在该部分只对instorestat.aspx页面进行了详细说明。该页面按往来单位显示退货单列表。点击“查看”,将转向instorelist.aspx页面,显示与对应往来单位有关的退货单据列表。退货查询统计页面instorestat.aspx如图5.7所示。图5.7 退货查询统计页面5.3.4 仓库管理模块的实现该模块包含三个页面:storemix.aspx(仓库调拨),storeset.aspx(仓库设置),storealarm.aspx(库存报警)。限于篇幅,本文只对storemix.aspx页面进行详细说明。在该页面
48、中,用户只需选择要调拨的商品和仓库,输入调拨数量,即可完成商品调拨。商品信息表shproduct中可能有多条相同商品,只是id字段不同,表示这些商品不再同一个仓库。因此,在实现商品调拨的时候,是根据numcode(条形码)字段来判断是否同一种商品。然后根据条形码和商品所在仓库,对其库存进行修改。仓库调拨页面sotremix.aspx如图5.8所示。图5.8 仓库调拨页面5.3.5 基础信息模块的实现该模块包含三个页面:classlist.aspx(商品分类设置页面),corplist.aspx(往来单位管理页面),productlist.aspx(商品信息管理页面)。本文只对其中的商品信息管理
49、页面进行详细说明。商品信息管理页面主要实现商品的添加,删除和修改。首先,在树形菜单中选择商品信息管理后,出现商品信息管理页面,然后再对其进行具体操作。商品信息管理页面productlist.aspx如图5.9所示。图5.9 商品信息管理页面在该页面中,列出了所有商品的信息,用户还可以输入商品拼音码来查询商品信息。点击列表中的商品名称,将跳转到添加/修改商品页面,从而对商品信息进行修改。点击“添加”按钮,也将跳转到添加/修改商品页面,不同的是,如果是修改商品,则对应商品原始信息将在该页面显示出来,修改后执行更新操作。修改商品页面productedit.aspx如图5.10所示。图5.10修改商品
50、页面如果是添加商品,该页面中的文本框全部为空。对于拼音码字段,如果用户不填写,系统将自动为其提取拼音码。添加商品页面productedit.aspx如图5.11所示。图5.11 添加商品页面5.3.6 系统管理模块的实现该模块包含三个页面:databack.aspx(备份数据库页面),sysuser.aspx(管理员设置页面),changepwd.aspx(修改密码页面)。在备份数据库页面,用户只需输入数据库名称就可对系统当前数据库进行备份,若不输入数据库名称默认的文件名为日期,以防止数据的丢失。备份数据库页面databack.aspx如图5.12所示。图5.12 备份数据库页面 在管理员设置
51、页面,用户可以对系统管理员的具体信息进行更新,即添加、删除、修改,本系统在设计时没有涉及权限问题,对登录后的所有用户开放所有权限。管理员设置页面sysuser.aspx如图5.13所示。图5.13 管理员设置页面在修改密码页面,登录的用户可以使用自己的登录密码进行密码修改,用户信息从cookie里面读取。修改密码页面changepwd.aspx如图5.14所示。图5.14 修改密码页面结 论本课题设计了一个超市进销存系统。首先通过分析超市运营业务和其管理的总体需求,在超市进销存管理系统的功能模块及数据库方面对系统进行了详细设计。系统成功地解决了超市的采购、销售和仓库管理等问题,实现了对超市内商品流动的实时监控,大大提高了超市的运营效率和管理水平。系统采用c# 为主要开发工具,结合sql sever数据库管理系统,设计时既考虑到系统的需求,又兼顾到运行效率和今后系统功能拓展等问题,设计出的系统具有运行效率高、开发周期短、扩展能力强、技术规范等特点。由于时间、精力和本人水
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度专利实施许可及技术转让合同2篇
- 足疗店技师合作协议1
- 医药销售协议
- 科普知识课件
- 国际磋商2024年度市场准入条件
- 2024版钢筋混凝土施工安全防护用品采购合同3篇
- 激励高二的教学课件教学课件教学
- 挖掘机买卖合同书范本
- 配电自动化系统设计与实施2024年度合同
- 个人承包2024年度库房消防演练合同3篇
- 相貌各异的我们教案及反思
- 低压电工作业复审模拟考试题及答案
- 金融工程学(第五版)第2章远期工具及其配置
- 函数的概念教学设计全国优质课
- 公司危险源辨识与风险评价和控制措施清单
- 特殊级抗菌药物会诊单及申请表
- 新教材人教版高中生物选择性必修第二册 2.1 群落的结构(第2课时) 教学课件
- 幼儿园中班数学活动《图形分类》
- Q-RJ 557-2017 航天型号产品禁(限)用工艺目录(公开)
- 食品安全法培训课件
- 曹龙骐版金融学课后习题答案全解
评论
0/150
提交评论