基于.net的超市管理系统设计与实现

基于.net的超市管理系统设计与实现

ID:11808564

大小:1.20 MB

页数:108页

时间:2018-07-14

上传者:U-10243
基于.net的超市管理系统设计与实现_第1页
基于.net的超市管理系统设计与实现_第2页
基于.net的超市管理系统设计与实现_第3页
基于.net的超市管理系统设计与实现_第4页
基于.net的超市管理系统设计与实现_第5页
资源描述:

《基于.net的超市管理系统设计与实现》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

沈阳理工大学应用技术学院毕业设计(论文)题目:基于.NET的超市管理系统的设计与实现系别:信息工程系专业:软件工程学生姓名:指导教师:王岩年月日IV 摘要本文首先简单给出了超市管理系统的设计背景和意义,并介绍了系统开发所用到的开发工具和语言,然后在进行了需求分析的基础上,说明了系统功能模块的划分及各模块之间的相互关系,然后着重论述了系统功能的一些重要的技术实现过程。本系统的每一个功能模块都包含了多个功能。整个系统主要完成对超市商品的日常管理,包括进货管理,销售管理,库存管理,员工管理和供应商管理等方面。在功能上系统可以完成对相关信息的浏览、查询、添加、删除、修改等功能。本课题的核心之一是销售管理、库存管理和进货管理三者之间的联系,同时系统有完整的用户管理及权限管理功能。本系统采用C#语言和SQLServer2005作为开发工具。这种系统优势在于系统比较简单,但功能强大,扩展性能也比较好,完全能够处理一般超市的日常任务。关键词:C/S架构;数据库;超市管理IV AbstractFirstly,thisarticlegaveoutthesupermarketmanagementsystemofthebackgroundandthemeaning,andthenitbrieflyintroducedthedevelopinginstrumentsandlanguagesusedforthesystem.Onthebasisofsystematicdemandanalysis,Thenthearticlemadeafunctionalanalysisfortheresourcereservationsystem,thethesisdemonstratedstructuresofthesystemfunctionandtherelationsofeachmodule.Finally,thearticlepaidmucheffortsinexplaininghowtoapplytheadvancedtechnologiesintothewholesystem.Systemfunctionalmoduleseachcontainanumberoffeatures.Thesystemwascompletedforthedailymanagementofsupermarketgoods,includingthepurchasemanagement,salesmanagement,inventorymanagement,staffmanagement,suppliermanagementandsoon.Functionallycompletedinformationsystemcanbrowse,search,add,delete,modifyandsoon.Thecoreofthisissuewasoneofsalesmanagement,inventorymanagementandpurchasemanagementlinksbetweenthethree,whilethesystemhadacompleteusermanagementandpermissionsmanagement.ThesystemusedtheC#languageandSQLServer2005asadevelopmenttool.Advantageofthesystemsuchasystemwasrelativelysimple,butpowerful,theexpansionofbetterperformance,fullywasabletohandleday-to-daytasksofthegeneralstore.Keywords:C/Sstructure;Database;SupermarketmanagementIV 目 录引言11基础知识31.1背景与意义31.2开发方法31.2.1C#语言介绍41.2.2SQLServer2005数据库优点41.2.3运行环境的选择52系统需求分析62.1系统功能概述62.1.1系统功能需求62.1.2用例分析82.1.3类图分析82.2系统性能要求92.2.1系统时间特性要求92.2.2系统灵活性92.2.3数据管理能力要求102.3可行性分析102.3.1技术可行性102.3.2经济可行性102.3.3操作可行性103系统概要设计113.1系统总体设计方案113.2系统数据流图123.3系统活动图143.4系统数据库设计153.4.1数据库需求分析153.4.2数据库概念设计(E-R图)153.4.3数据库逻辑设计18IV 4系统的详细设计234.1系统主要功能模块设计234.1.1登录模块流程234.1.2进货管理流程244.1.3销售管理流程244.1.4库存管理流程254.2系统主要功能模块实现264.2.1登录模块实现264.2.2进货管理模块实现274.2.3销售管理模块实现284.2.4库存管理模块实现294.2.5权限管理模块实现305系统测试325.1系统测试步骤325.1.1单元测试325.1.2集成测试325.1.3确认测试335.2系统测试345.2.1界面测试345.2.2功能测试34结论36致谢37参考文献38附录附录清单A39附录附录清单B46IV 沈阳理工大学应用技术学院学士学位论文引言在我国超市形成在20世纪90年代初期,现在已经成为我国零售业的一种重要形态,为国民经济的发展起发挥了极大的作用。随着超市高速的发展,其经营管理也变得愈加复杂,早期的售货员站柜台的形式早已不能满足现有销售也的发展,这样就迫切地需要引入新的管理技术。随着经济的高速发展,超市的信息化工作也在紧锣密鼓地进行,与此同时伴随着超市规模的不断扩大以及各种信息流量的日益增多,其经营管理也变得愈加复杂,而且以往在超市日常管理中,商品进货、销售、库存等决策主要以经验为主,缺乏实时分析功能,并且伴随着商业运转的中间环节也越来越多,因此以前的手工操作方式就不能适应超市快速的信息发展的需要,而在计算机科学技术日益发展和成熟的今天,依靠现代化的计算机信息处理技术来管理超市日常工作中的各类商品及用户的信息数据,既节省了大量的人力、物力、改善了员工的工作条件,减轻了劳动强度,同时也能够快速反映出商品的进销存状况和各种反馈信息分析,使管理人员快速对市场的变化做出对应决策,加快超市的发展。从而极大地提高超市的工作效率。超市形态具有很多优点,但在目前状况下,它仍存在零售企业所固有的落后的一面,如:不能有效地管理每种商品,收款结算速度慢,容易出现营业差错,不宜进行商品调价,盘点效率低等,而且在超市日常管理中,商品的进、销、存等决策以经验为主,缺乏实时分析功能,管理人员对及时传递资料的要求始终得不到满足。随着超市形态的高速发展,其经营管理也变得愈加复杂,日常所需要处理的数据量也逐渐扩大,商业运转的中间环节也越来越多,原始的人工管理已无法应对这复杂的市场。超市需要处理大量的库存信息,还要时刻更新产品的销售信息,不断添加商品信息。面对不同种类的信息,需要合理的数据库结构来保存数据信息,需要有效的程序结构支持各种数据操作的执行。商店自动化的产品管理在欧美等国家早已经实现,也是零售业管理的基础。它最主要的特点是能够实时的和准确的控制店内的销售情况。如果能够实时掌握销售流程及销售情况,则可以有效地加速商品的周转率并提高服务质量,而且可以减少产品售价不符等所产生的问题。顾客的消费要求是希望在超市购物中基本上能购得到自己所需的商品,并且还要既保证商品质量还要享受优质、方便的服务。本文中共分5章。第一章基础知识,主要讲超市管理系统的背景、意义,开发方法及开发2 沈阳理工大学应用技术学院学士学位论文工具简介;第二章系统需求分析,主要讲系统功能需求、性能需求及可行性分析;第三章概要设计,主要介绍系统工作流程、功能结构图及数据库表设计;第四章详细设计,主要讲各个功能的工作流程及具体的实现过程。第五章系统测试,主要介绍系统使用的测试方法及测试用例并计算系统的稳态可用性。每章附有本章重点介绍的功能图例及详细讲解,帮助理解系统的各部分功能。2 沈阳理工大学应用技术学院学士学位论文1基础知识1.1背景与意义随着现代科学技术的迅猛发展,计算机技术已经渗透到各个领域,成为各行业必不可少的工具,特别是Internet技术的推广和信息高速公路的建立,使IT产业在市场竞争中越发显示出其独特的优势,步入信息化时代,有巨大的数据信息等待加工处理和传输,这使得对数据库的进一步开发和利用显得尤为迫切。而作为国内市场的一些中小型超市,它们在信息化过程中的步伐要落后于大中型超市,而对于这些企业的资源管理,信息的存储和处理也显得迫切需要,要适应市场竞争,就需要有高效的信息处理方式和管理方法,因此加快超市的信息化进程是必可少的。小超市形态本身具有种种特点,在原先状况下不能有效地管理每种商品,收款结算速度慢,容易出现营业差错,不宜进行商品调价,盘点效率低等,而且在超市日常管理中,商品的进、销、存等决策以经验为主,缺乏实时分析功能,管理人员对及时传递资料的要求始终得不到满足。小超市形态的高速发展,其经营管理也变得愈加复杂,日常所需要处理的数据量也逐渐增大,商业运转的中间环节也越来越多,原始的人工管理已无法应对这复杂的市场。为了适应日趋激烈的市场竞争,各类型的超市需要对自身的经营状况有充分的了解,并通过有效的管理不断提高效率。为此,超市管理系统便显得尤为重要了,依靠现代化的计算机信息处理技术来管理超市,是对超市整体信息的管理成为提高经营效率的一个重要途径。1.2开发方法本系统采用C#作为前台开发工具。后台数据库采用SQLServer2005数据库,因为它的灵活性、安全性和易用性为数据库编程提供了良好的条件。利用三层结构技术,即表示层、逻辑层、数据服务层[1]。这三层被分成三个相对独立的单元。表示层负责与用户交互,并把相应的请求通过调用中间层的组件传递给逻辑层;逻辑层通过组件执行具体的事务逻辑,通过SQL等方式向第三层的组件提出数据或其他资源请求。表示层在客户端的应用浏览器中运行,数据访问也在专用的数据库服务器上运行。采用三层结构能很好的解决软件的可扩展性、安全性、管理性等关键问题。 沈阳理工大学应用技术学院学士学位论文1.2.1C#语言介绍C#是一种安全的、稳定的、简单的,由C和C++衍生出来的面向对象的编程语言。它在继承C和C++强大功能的同时去掉了一些它们的复杂特性(例如没有宏和模板,不允许多重继承)[2]。C#综合了VB简单的可视化操作和C++的高运行效率,以其强大的操作能力、优雅的语法风格、创新的语言特性和便捷的面向组件编程的支持成为.NET开发的首选语言。C#语言的主要优点大概可以归纳如下:1、语法简洁:C#取消了指针、也不定义繁琐的伪关键字;它使用有限地指令、修饰符合操作符,语法上几乎不存在任何冗余,整个语言结构十分清晰。初学者通常能够快速掌握C#基本特性,而C/C++程序员转入C#则几乎不会有什么障碍。2、完全面向对象:C#具有面向对象的语言所应有的基本特性:封装、继承和多态性。它禁止多继承,禁止各种全局方法、全局变量和常量。C#以类为基础来构建所有的类型,并通过命名空间对代码进行层次化的组织和管理。许多精巧的对象设计模式都在C#语言中得到了有效的应用。3、目标软件的安全性:C#符合通用类型系统的类型安全性要求,并用CLR所提供的代码访问安全特性,从而能够在程序中方便的配置安全等级和用户权限。此外,垃圾收集机制自动管理对象的生命周期,这是的开发人员无需再负担内存管理的任务,应用程序的可靠性进一步得到提高。4、版本管理技术:C#语言中内置了版本控制功能,并通过接口和继承来实现应用的可扩展性[3]。应用程序的维护和升级更加易于管理。5、灵活性与兼容性:C#中允许使用非托管代码来与其他程序(包括COM组件、WIN32API等)进行集成和交互。它还可以通过委托(delegate)来模拟织针的功能,通过接口来模拟多继承的实现。1.2.2SQLServer2005数据库优点SQLServer2005的一个重要设计目标就是提高默认状态下的安全系数。为了缩小被攻击范围,最危险的一些特性都被禁用,除非数据库管理员启用它们。这有所帮助,不过对有经验的数据库管理员来说帮助不大。他们基本上会编写锁定脚本,觉得安装时加以运行不是很麻烦。安全方面真正重要的改进则是密码管理和权限分配方面。现在可以设置原始SQL密码来顾及Windows密码政策,这意味着用户可以要求SQL密码拥有与Windows账户同样的密码强度、失效日期、历史、锁定 沈阳理工大学应用技术学院学士学位论文阈值、锁定时间及生命期等政策,甚至可以要求用户在下次登录时更改密码。安全方面的其他重要改进还包括:加强了对模式变更的控制、能够对数据进行列级加密。SQLServer2005不但克服了高可用性和灾难恢复方面的缺点,还几乎在各个方面都有了全面改进:管理任务得到了简化;监控和诊断功能得到了增强;默认的锁定配置、数据加密及其他新特性增强了安全。如今,分析服务(AnalysisServices)、报表服务(ReportingServices)和数据挖掘(DataMining)全面集成,而且已经很成熟。数据转换服务(DTS)已从头到尾经过了改写,已逐渐成为更强大、更灵活的SQL服务器集成服务(SSIS)。与VisualStudio和.Net/CLR的集成,把SQLServer的内部机制展现给了.Net开发人员、把.Net的内部机制展现给了SQL开发人员。这意味着,现在就可以利用.Net的强大功能,用于存储过程、数据流和数据转换、商业智能等应用的。1.2.3运行环境的选择由于计算机发展迅速,为将来升级的考虑,这里所提供的硬件设备要比能够运行该系统所需要的最低硬件标准高出一些。1.软件环境:操作系统:采用WindowsXP或Windows2003以上;开发工具:MicrosoftSQLServer2005;C#2.硬件环境:CPU:IntelPentium(R)4以上;内存:512M;硬盘:80G;网卡:100M。 沈阳理工大学应用技术学院学士学位论文2系统需求分析软件需求分析就是把软件计划期间建立的软件可行性分析求精和细化,分析各种可能的解法,并且分配给各个软件元素。需求分析是软件定义阶段中的最后一步,是确定系统必须完成哪些工作,也就是对目标系统提出完整、准确、清晰、具体的要求。需求分析是介于系统分析和软件设计阶段之间的重要桥梁。一方面,需求分析以系统规格说明和项目规划为分析活动的基本出发点,并从软件角度对它们进行检查与调整;另一方面,需求规格说明又是软件设计、实现、测试直至维护的主要基础[4]。良好的分析活动有助于避免或尽早剔除早期错误,从而提高软件生产率,降低开发成本,改进软件质量。2.1系统功能概述本系统主要完成超市管理(商品信息管理、供货商管理、进货管理、退换货管理、商品销售管理、客户管理、客户退货管理、仓库设置、库存管理)等功能。通过以上功能实现简单、便捷的超市管理系统。2.1.1系统功能需求1、商品信息管理:管理员可以对商品进行添加、修改和查询操作。添加库存商品时候要填入:商品名称、入库价格(即进货价格,进货价格的查询只能是以管理员身份登录才能查看)、商品卖价(同入库价格一样)、单位、预警量(及库存下限)。最主要的是对商品信息进行查询:商品信息查询可以根据商品类型查询(类型一般分为:日用品、食品、药品、电器、衣物、床上用品),还可以精确查找(需要输入商品编号、商品类型),还可以模糊查询(需要输入商品名称、商品价格)查询结果包括:商品编号、商品名称、商品类型、商品售价、商品数量。2、供货商管理:供货商管理可以对厂商信息进行查询。供货商信息查询可以根据厂商名称查询、负责人查询和最近联系厂商查询。查询结果包括:供货商。3、进货管理:进货管理需要对每次的进货进行登记,登记需要填写:(订单信息):单号(随机产生流水号)、收货仓库、进货时间、供货商名称、经办人(所有的经办人都是登录的用户)、总金额、应付金额、实付金额、备注(订单信息):商品编号、商品名称、单位、规格型号、颜色、单价、数量。 沈阳理工大学应用技术学院学士学位论文进货查询可以根据进货时间、供货商、商品类型、负责人查询。进货的同时需要进行入库登记:商品名称、进货价格、出售价格、商品数量、商品类型、供货商、经办人、商品总价。4、退换货管理:退换货管理是但进货产品出现质量问题、货物迟到等原因超市和供货厂商协商要求退货或换货进行详细登记。退货方式有两中:一种是整单退货,一种是部分退货。登记内容包括:(订单信息):单号(随机产生流水号,是唯一的)、出货仓库、退货时间、供货商名称、总金额、应退金额、实退金额、经办人、备注(订单信息):商品编号、商品名称、单位、规格型号、颜色、单价、数量。退货查询可以根据单据号、供货商和开单时间查询。查询结果包括:单号、开单时间、供货商名称、仓库名称、经办人、总金额(单据详细信息):商品编号、商品名称、单位、规格型号、颜色、单价、数量。5、商品销售管理:销售登记需要登记:(单据信息):单号、客户名称、出货仓库、销售日期、总金额、应收金额、实收金额、经办人、备注(订单信息):商品编号、商品名称、单位、规格型号、颜色、单价、数量。需要出库登记:商品名称、出库数量、经办人、出库时间。6、客户管理:客户管理主要是对与本超市的有过交易记录的人群的信息进行登记和查询。登记客户信息包括:客户名称、负责人、联系地址、联系电话。查询可以通过时间来查询(查询最近联系的客户)、客户名,查询最近联系的客户。7、客户退货管理:客户退货管理是在本超市购买商品之后,但产品出现质量问题、货物迟到等原因超市和客户协商要求退货或换货的制度。客户退货需要登记:单号、(订单信息)客户名称、收货仓库、收货日期、总金额、应退金额、实退金额、经办人、备注(订单信息):商品编号、商品名称、单位、规格型号、颜色、单价、数量。销售退货查询可以根据:客户名称、单据号、开单日期查询。需要注意的是:客户退货之后是退回到仓库,所以要进行入库登记。8、仓库设置:仓库设置也包括添删改的操作:仓库名称、负责人、联系电话、仓库地址、仓库信息备注。9、库存管理:库存出入登记及商品在进出仓库的时候都需要登记。入库的情况包括:商品的采购、客户退货。出库的情况包括:商品销售、采购退货。库存的出入查询可以根据:单据号、时间来查询。查询结果包括:(单据信息)单号、出入的仓库、出入仓库的日期、经办人。添加库存商品及添加商品种类,添加是需要登记:商品名称、入库价格、商品卖价、单位、及库存下限。同时还具有库存商品预警查询功能。 沈阳理工大学应用技术学院学士学位论文2.1.2用例分析用例图主要用来图示化系统的主事件流程,它主要用来描述客户的需求,即用户希望系统具备的完成一定功能的动作,通俗地理解用例就是软件的功能模块,所以是设计系统分析阶段的起点,本文中采用用例技术进行需求分析的获取和分析。为了能够正确的找出系统的用例,需要确定系统的边界,找出系统的执行者。用例图如图2.1所示。图2.1超市管理系统用例图2.1.3类图分析类图(Classdiagram)由许多(静态)说明性的模型元素(例如类、包和它们之间的关系,这些元素和它们的内容互相连接)组成。类图可以组织在(并且属于)包中,仅显示特定包中的相关内容。类图描述的是一种静态关系,在系统的整个生命周期都是有效的。在类描述中一般只给出主要类及主要类间的关系。类图是所有面向对象建模方法的核心部分,类图描述了系统的静态结构,由类及类间的关系组成。类是具有相同属性和相同方法的对象的集合,系统类图如图2.2所示。 沈阳理工大学应用技术学院学士学位论文图2.2超市管理销售系统类图2.2系统性能要求对系统性能的要求包括对系统时间要求,灵活性,数据管理能力等的要求。2.2.1系统时间特性要求系统的速度要在用户可接受的范围内,但考虑到需要实时检测商品的数量和库存情况,对资源实时搜索的速度可以有较低的要求。2.2.2系统灵活性系统要有良好的接口,以适应增加商品信息,增加商品类型,增加相关的商品录入功能的需求;增加商品信息的更改和更新功能。 沈阳理工大学应用技术学院学士学位论文2.2.3数据管理能力要求系统要有较高的管理能力,本系统采用的是SQLServer2005数据库。具有较强的数据处理能力,数据库引擎增强、分析服务增强等。记录的个数随用户多少不定,数据及其分量的存储量为10G,但能保证注册的用户都能登录进来,没有延时。2.3可行性分析可行性分析是依据初步调查的结果做出系统开发可行与否的结论过程。任何一个工程的立项都需要进行项目的可行性分析。可行性研究的目的就是用最小的代价在尽可能短的时间内确定问题是否能够解决、是否值得去解决。根据调查分析,系统设计方案有以下三个可行性。2.3.1技术可行性根据前期的市场调查与对下列系统功能、性能及实现系统的各项所需技术的约束条件的分析来看,本系统程序开发应是一个集数据库管理和查询为一身的系统,依据现有的开发技术,开发硬件、开发软件的性能要求及环境条件等来看,各项条件良好,同时,考虑给予的开发期限较为充裕,预计可以在规定期限内完成预定功能地开发与实现。在软件方面本程序设计采用的开发环境是MicrosoftVisualStudio2005,采用开发语言C#编写程序,采用SQLServer2005做后台数据库。在硬件方面电脑的各种配置包括输入输出能力,内部存储器和外部存储器的容量都能满足用户的要求。2.3.2经济可行性本超市管理系统,其前期的投入比较小,主要是系统的设计费用:其中包括软件开发费用、管理和维护费等。而后续的投入相对较小,很长时间内都不会需要进一步投资,管理和维护费用也很少,而系统实际能够起到的作用会远远大于投入的开发费用,相信会有十分可观的前景。因此这个系统很有开发价值。2.3.3操作可行性本系统界面清晰直观、易于操作。由于它能够准确记录、检索和管理有关超市各类商品信息和用户信息,帮助超市经营者掌握和分析营销情况,及时做出正确决策,并且便于超市相关内部人员对商品的管理,因而大大提高了超市的管理水平与效率。综上所述,从经济可行性、技术可行性和操作可行性来说,系统开发是完全可行的。 沈阳理工大学应用技术学院学士学位论文3系统概要设计本阶段完成系统的大致设计并明确系统的数据结构与软件结构。在软件设计阶段主要是把一个软件需求转化为软件表示的过程。在概要设计阶段的指导思想是结构化指导思想,是指用一组标准的规则和图表工具确定系统有哪些模块,怎么连接,从而形成新系统的结构,然后再进行诸如输入、输出、对话等设计,为整个系统的实施做好铺垫。3.1系统总体设计方案本系统采用了C/S模型。系统前台采用C#语言来设计,访问数据库服务器;后台采用Microsoft公司的SQLServer2005。SQLServer2005开发后台数据库,用于提供数据服务。SQLServer2005是一种典型关系型数据库管理系统,该系统具有数据一致性好,完整性强,安全性高的优点,系统采用结构化设计方法,按超市实际工作内容来确定所需,将整个系统作为一个大模块自顶向下,以模块化结构设计技术进行模块分解,然后再自底向上,按照系统的结构将整个模块进行组合,最终完成本超市管理系统的开发。本系统有四个整体模块,其包含着以下子模块。具体的模块功能划分如下:用户登录模块:具备登录用户、添加登录用户、用户密码修改功能。商品信息管理模块:提供添加商品类型,修改商品信息、商品信息查询、商品类型管理功能。  厂商管理模块:具备厂商信息查询、添加厂商、修改厂商信息的功能。 进货管理模块:提供进货登记、进货查询的功能。  进货退换管理模块:提供退货登记、退货查询功能。商品销售管理模块:提供销售登记、销售查询功能。  客户退货管理模块:提供销售退货登记、销售退货查询功能。客户管理模块:具备客户信息查询功能。库存管理模块:提供库存出入登记、库存出入查询、库存查询、添加库存商品、库存商品预警查询功能。本系统详细功能模块图如图3.1所示。 沈阳理工大学应用技术学院学士学位论文图3.1系统功能模块图3.2系统数据流图数据流图是将提供给用户的业务流程图进行功能建模,转化成开发人员能够理解的一系列“逻辑模型”图,即以图形化的方法描绘数据在系统中的流动和处理的过程,这些图都应该用规范的DFD描述。本系统操作流程,操作员根据不同的身份账号进入登录模块,在登录栏处输入用户名和密码,系统进行验证操作员身份,若系统没有检索到用户名,则不允许进入,进去后根据所拥有的权限进行操作。超级管理员拥有所有权限可选择某种商品种类,点击进入商品信息管理模块,查看商品细售价等信息,销售模块和进货模块可以修改进货和销售清单。在客户管理模块中可以查看客户详细的通讯地址、联系方式、订单状态等信息, 沈阳理工大学应用技术学院学士学位论文同时会验证客户所填写的信息是否正确,若无误,则保存正确信息,否则不处理此订单,在库存模块当中操作入库、出库、查询等。本系统的数据流图是比较清晰的,对各功能模块来说都比较有规律。系统的第二层层和第一层数据流图分别如图3.2和图3.3所示。基础信息录入商品销售基础数据基础信息库存信息库存总量商品进货单商品入库单购买的商品销售凭条业务查询库存信息库存总量查询条件结果输出图3.2第二层数据流图 沈阳理工大学应用技术学院学士学位论文超市管理员超市管理系统数据查询登录信息查询结果图3.3第一次层数据流图查询条件供应商进货单入库单顾客购买的商品凭条3.3系统活动图活动图阐述了用例实现的过程,用于研究实现业务目标时所要执行的各项任务或活动的顺序安排。本超市管理系统的活动图如图3.4所示。图3.4超市管理系统活动图 沈阳理工大学应用技术学院学士学位论文3.4系统数据库设计数据库设计是建立数据库及应用系统的技术,是信息系统开发和建设中的核心技术,具体说,数据库设计是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及应用系统,使之能够有效地存储数据,满足各种用户的要求数据库设计是管理信息系统的重要组成部分[5]。这里采用SQLServer数据库。该数据库对行增、删、修改、统计、显示和应答都极为方便。其中的排序和索引功能,对数据快速定位、查询提供了有利条件。3.4.1数据库需求分析主要是收集基本数据及确定数据的处理要求,需求分析主要解决如下问题:1、数据要求:用户需要从数据库中获取什么数据,并决定在数据库中存储那些数据。2、操作要求:明确用户对数据的操作要求,从而确定数据之间的关系。3.4.2数据库概念设计(E-R图)概念结构设计是整个数据库设计的关键,它能通过对需求进行综合,归纳与抽象,形成一个独立于具体DBMS的概念模型,即E-R图[6]。简单的说,E-R图用来分析数据关系的。下面具体超市管理系统主要的实体图。管理员实体图如图3.5所示。管理员用户名用户密码用户等级图3.5管理员实体图商品信息实体图如图3.6所示。 沈阳理工大学应用技术学院学士学位论文商品信息编号名称单价分类库存销售图3.6商品信息实体图进货管理实体图如图3.7所示。进货管理备注商品编号进货数量进货编号进货日期总价单价办理人图3.7进货管理实体图销售管理实体图如图3.8所示。 沈阳理工大学应用技术学院学士学位论文销售管理销售编号商品编号销售日期销售人支付方式销售单号销售数量总金额会员卡号图3.8销售管理实体图实体间E-R图如图3.9所示。图3.9实体间E-R图 沈阳理工大学应用技术学院学士学位论文3.4.3数据库逻辑设计逻辑结构是把概念结构转换为某个DBMS所支持的数据模型,并对其进行优化。本系统根据E-R图可以对数据库进行设计,以下列出主要的数据表。用户信息表如表3.1所示:表3.1用户信息表字段字段名类型是否为空备注userId用户IDint否主键,标识列userName用户姓名Varchar(20)否长度至少为6位至18位,并且不能有空格userSex用户性别Varchar(4)否取值只能为‘男’或‘女’,默认取值‘男’userAge用户年龄int否外键,引用类型取值表userXueLi用户学历Varchar(20)否大专、本科userAddress用户地址Varchar(50)否userPhone用户电话Varchar(30)否userIdCard身份证号Nvarchar(30)否只能是15为或18位userTypeID用户类型int否引用User(userTypeID)userPwd用户密码Varchar(20)否长度至少为6位至18位,并且不能有空格商品类型表如表3.2所示。表3.2商品类型表字段字段名类型是否为空备注goodsTypeID商品类型IDint否主键,标识列goodsType商品类型Varchar(20)否日用品、食品、药品、电器、衣物、床上用品供货商信息表如表3.3所示。表3.3供货商信息表字段字段名类型是否为空备注businessID供货商编号int否主键,标识列businessName供货商名称Varchar(20)否businessAddress供货商地址Varchar(50)否businessMain负责人Varchar(20)否businessPhone联系电话Varchar(30)否 沈阳理工大学应用技术学院学士学位论文用户类型表如表3.4所示。表3.4用户类型表字段字段名类型是否为空备注userTypeID用户类型IDint否主键,标识列userType用户类型Varchar(20)否(管理员、普通用户),默认为‘管理员’仓库类型表如表3.5所示。表3.5仓库类型表字段字段名类型是否为空备注storehouseTypeID仓位类IDint否主键,标识列storehouse仓位类型Varchar(10)否客户信息表如表3.6所示。表3.6客户信息表字段字段名类型是否为空备注clientID客户IDint否主键,标识列clientName客户名称Varchar(20)否clientMain负责人Varchar(50)否clientAddress联系地址Varchar(20)否clientPhone联系电话Varchar(30)否仓库设置表如表3.7所示。表3.7仓库设置表字段字段名类型是否为空备注storehouseID仓库IDint否主键,标识列storehouseName仓库名称Varchar(20)否storehouseTypeID仓位类型int否外键,仓库类型表storehouseMain负责人Varchar(20)否storehousePhone联系电话Varchar(30)否storehouseAddress仓库地址Varchar(50)否storehouseRemark信息备注Varchar(30)否仓库信息表如表3.8所示。 沈阳理工大学应用技术学院学士学位论文表3.8仓库信息表字段字段名类型是否为空备注StoreInfoID仓库信息IDint主键stockrOderFormID进货单号int否外键引用myRetuOrderFormID采购退货单号int否外键引用采购退货订单信息表sellOderFormID销售单号int否外键引用商品销售订单表returnOrderFormID客户退货单号int否外键引用客户退货单据信息表商品信息表如表3.9所示。表3.9商品信息表字段字段名类型是否为空备注goodId商品编号int否主键,标识列goodsName商品名称Varchar(20)否goodsPrice商品进价money否(即入库价格),价格要大于0goodsTypeID商品类型Varchar(10)否外键,引用商品类型表goodsNum商品数量int否sellPrice商品售价money否商品售价要大于商品进价unitsID单位int否外键,引用单位类型表model规格型号Varchar否color颜色Varchar(5)否Price单价money否大于0totalMoney总金额money否只是一种商品的总金额waringNum库存提醒数int否大于等于0进货单详细表如表3.10所示。表3.10进货单详细表字段字段名类型是否为空备注StockID进货订单详细IDint否主键,标识列stockrOderFormID进货单号int否外键引用进货订单表(Stock)goodsID商品编号int否外键引用商品信息表(GoodInfo) 沈阳理工大学应用技术学院学士学位论文进货订单表如表3.11所示。表3.11进货订单表字段字段名类型是否为空备注stockrOderFormID进货单号Varchar(30)否主键,标识列storehouseID收货仓库int否外键引用仓库设置表stockTime进货时间datetime否businessID供货商名称int否外键stockMain经办人Varchar(20)否stockTotalMoney总金额money否大于0stockShouldPay应付金额money否应付金额等于总金额stockFactPay实付金额money否stockRemark进货备注Varchar(50)否商品销售订单表如表3.12所示。表3.12商品销售订单表字段字段名类型是否为空备注sellOderFormID销售单号Varchar(30)否主键,标识列clientID客户名称int否键引用客户表storehouseID收货仓库int否外键引用仓库设置表sellTime销售日期Datetime否外键sellTotalMoney总金额Varchar(20)否sellShouldMoney应退金额money否大于0sellFactMoney实退金额money否应付金额等于总金额sellMain经办人Varchar(20)否sellRemark销售备注信息Varchar(50)否销售订单详细表如表3.13所示。表3.13销售订单详细表字段字段名类型是否为空备注SellX销售订单详细IDint否主键,标识列sellID销售单号int否外键引用商品销售订单表goodId商品编号IDint否外键引用商品信息表 沈阳理工大学应用技术学院学士学位论文客户退货单据信息表如表3.14所示。表3.14客户退货单据信息表字段字段名类型是否为空备注returnOrderFormID客户退货单号Varchar(30)否主键,标识列clientID客户名称IDint否外键引用客户信息表storehouseID收货仓库IDint否外键引用)仓库设置表returnTime退货时间Datetime否外键供货商信息表returnMoney总金额money否returnShouldMoney应退金额money否大于0returnFactMoney实退金额money否应付金额等于总金额returnMain经办人Varchar(20)否returnMark退货备注信息Varchar(50)否客户退货单据详细表表如表3.15所示。表3.15客户退货单据详细信息表字段字段名类型是否为空备注ReturnID客户退货详细IDint否主键,标识列ReturnOrderFormID退货单号int否外键引用客户退货单据信息表goodsID商品编号int否外键引用商品信息表 沈阳理工大学应用技术学院学士学位论文4系统的详细设计详细设计的根本目标是确定应该怎样具体地实现所要求的系统,也就是说,经过这个阶段的设计工作,应该的出对目标系统的精确描述,从而在编码阶段可以把这个描述直接翻译成用某个设计的语言书写的程序。详细设计的任务不是具体的编写程序,而是要设计出程序的“蓝图”,以后可根据这个蓝图写出实际的程序代码。详细设计的目标不仅仅是逻辑上正确地实现每个模块的功能,更重要的是设计出的处理过程应该尽可能简明易懂。本系统所包括的几大模块如下:登录模块、进货模块、库存管理模块、销售管理等多个模块。4.1系统主要功能模块设计4.1.1登录模块流程本模块的主要功能是对用户身份进行验证,只有系统的合法用户才能进入系统。在进行系统登录过程中,登录模块将调用数据库里的用户清单,并对账号和密码进行验证,只有输入了正确的账号和密码后,系统登录才会成功。并在输入了错误的或者是不存在的账户和密码时,系统会提示出错信息,指明登录过程中的错误输入或者错误操作,以便用户进行正确的登录。系统登录模块流程如图4.1所示。图4.1登录模块流程图 沈阳理工大学应用技术学院学士学位论文4.1.2进货管理流程功能:该模块主要是实现进行进货信息查询功能。进货信息查询:该模块为超市提供整个超市的进货情况查询,也可以进行进货信息的明细查询。输入项、输出项:该模块的输入项为超市的进货单,其中包括进货单的编号、商品的编号、供货商号、进货价、数量、金额进货日期和备注。进货管理流程如图4.2示:图4.2进货管理流程图4.1.3销售管理流程功能:本模块的主要功能是把销售信息写入销售清单,同时对库存清单进行更新,以备用户将来对库存信息进行查询和打印,此外还可以对销售信息进行查询和盘点功能。 沈阳理工大学应用技术学院学士学位论文销售信息查询:根据商品销售情况,按需要对销售情况进行查询。在该查询模块中,可以按照商品的编号、销售日期等多种方式进行商品销售信息查询。销售信息盘点:可以按照需要对在一定时期内的销售情况进行盘点。输入项、输出项:本模块的数据输入项主要是商品的销售单号和商品编号。其中还包括销售数量和销售日期。销售管理流程如图4.3所示。图4.3销售管理流程图4.1.4库存管理流程功能:本模块的主要功能是商品信息的查询和更新,库存信息的查询和更新。查询商品信息:主要功能查询商品的明细信息,和它的库存信息。添加商品信息:主要功能添加新进的商品。修改商品信息:主要功能是修改商品的信息,包括他的库存数量。删除商品信息:主要功能是删除不再销售的商品信息。输入项、输出项:本模块的数据输入项主要是商品编号。 沈阳理工大学应用技术学院学士学位论文库存管理流程如图4.4所示。图4.4库存管理流程图4.2系统主要功能模块实现4.2.1登录模块实现为了提高软件操作安全性,用户进入系统前,需进行身份验证,通过此窗体输入个人信息以验证身份。再输入过程中也可以通过虚拟键盘来输入,如果用户名和密码都正确,单击登录按钮,则进入系统。如果输入错误,则会提示密码错误,继续输入,如果连续3次错误,则会退出系统。系统登录界面如图4.5所示。 沈阳理工大学应用技术学院学士学位论文图4.5登录模块实现过程:在登录界面中实现中通过BindAllUsers()来绑定用户类型,MemorizePwd()来记住密码。当登录窗体加载的时候就进行查询,如果LoginJilu表中最大ID的state=0的时候就表示上次登录的用户选中了,否则没有选中,如果选中了就根据用户ID到users表中把用户姓名和密码查找出来。DataTabledtUserId=um.GetUserIdByUserNameAndPwd(name,pwd);intuserId=Convert.ToInt32(dtUserId.Rows[0]["userId"])。如果用户名或密码不正确,则记载输入错误密码的次数,如果密码错误次数多余系统设置的数据,则会自动退出系统。DataTablecishu=um.GetTime();为了便于鼠标点击输入。调用电脑的虚拟键盘代码如下:System.Diagnostics.Process.Start("osk.exe")。4.2.2进货管理模块实现商品的进货管理是超市管理系统中的一个非常重要的功能,在庞大的商品信息中,能够及时添加所缺少的商品,是超市经营中一个重要的环节。本系统采用商品数量预警方案,当商品数量下降到预警范围内。管理员就会及时发现缺的商品,从而进货。本模块对商品的录入进行操作。进货管理模块如图4.6所示。 沈阳理工大学应用技术学院学士学位论文图4.6进货管理模块实现过程:建立采购购物车,然后给购物车绑定数据,并调用购物车的数据。将购物车的商品显示到采购窗体上面,并将商品类型绑定到树形控件上,实例化树节点,保存商品的编号,用递归调用方法添加子节点,并展开所有节点。详细流程如下:如果已经采购了商品,添加采购订单详表的数据,for(inti=0;i0),如果已经购买了所选中行的商品,就只进行数量的增加if(dr["商品名称"].ToString()==name2),调用更新数据库库存,并绑定新数据gm.UpdateGoodsNum(newGoodsNum,goodsID);并将购物车中的商品显示到销售窗体上。doublesunMoney1=0;for(inti=0;i

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。
大家都在看
近期热门
关闭