1、学号 毕业设计题目:小型超市收银系统的设计与实现 作 者 届 别 2011 届 院 别 计 算 机 学 院 专 业 计 算 机 科 学 与 技 术 指 导 教 师 职 称 讲 师 完 成 时 间 2011 年 5 月 20 号 I摘 要随着销售行业竞争日益激烈,小型超市收银系统的引入显得极其重要。它不但可以提高进销存管理的工作效率,而且可以有效减少盲目采购、降低采购成本、合理控制库存、减少资金占用并提高市场灵敏度,从根本上提升超市的市场竞争力。本系统运用计算机管理信息技术,建立数据库,对超市的进销存过程进行详细的分析,实现了对超市的进货、销售和库存的科学管理。它主要包括以下几大模块:登录模块、
2、商品入库模块、商品销售模块、营业统计模块、商品信息模块、供应商信息模块、用户信息模块。各模块相许独立,同时又构成统一的整体。本文主要介绍了小型超市收银系统的环境、所用到的开发语言、功能作用、设计的方案等各方面的内容,其目的在于让使用者了解此系统,使他们能更好的运用本系统,使此系统发挥出应有的作用。另外在文中还予以指出了系统开发有待于进一步完善发展的方向。关键词:收银系统;控件;窗体;.net 平台IIABSTRACTWith the increasingly fierce competition in sales industry, the introduction of small supe
3、rmarket cashier system is very important. It can not only improve the working efficiency of the purchase-sell-stock management, but also can effectively reduce the blind procurement, reduce procurement cost, have the reasonable control of inventory, reduce capital that takes up and improve market se
4、nsitivity, fundamentally ascending supermarket market competitiveness.This system uses computer-information-management technology, establish the database of supermarket. With a detailed analysis of the supermarket, it achieves the functions of purchasing and the scientific management of sales and st
5、ock. It includes the following major modules: login module, storage module of goods, merchandise sales module, operating statistics module, product information module, the module supplier information, user information module. Phase allowed to independently of each module, at the same time constitute
6、 a unified whole.In this paper, a small supermarket cash register system environment, the language used in the development, function, design and other aspects of the program, which aims to allow users to understand this system so they can better use the system, so that This system play its due role.
7、 Also in the article we pointed out that the system should be with further improved development.Key words: the cashier system; Control; Form; T platformV目 录摘 要 IABSTRACT II1 绪 论 11.1 研究课题的目的 .11.2 研究课题的意义 .22 需求分析 .32.1 可行性研究 .32.2 需求分析 .32.3 开发环境介绍 .43 总体设计 .73.1 设计思想 .73.2 设计原则 .73.3 功能模块和结构设计 .73
8、.4 数据库设计 .94 系统实现 164.1 登陆系统模块 164.2 商品信息模块 174.3 商品入库模块 184.4 商品销售模块 194.5 营业统计模块 234.6 供应商模块 244.7 用户信息模块 265 总结 27参 考 文 献 .28致 谢 29附 录 .30毕业设计共 41 页,第 1 页1 绪 论随着现代科学技术的迅猛发展,人们的生活方式正发生着巨大的变化。计算机技术已经渗透到各个领域,成为各个行业必不可少的工具。特别是 Internet 技术的推广和信息高速公路的建立,使得 IT 产业在市场竞争中越发显示出其独特的优势。科学技术是第一生产力,科学技术的发展让人类更加
9、受益。各类信息系统应用于各行各业,不但给管理上带来了极大的便利,而且还提高了工作效率。中小型超市在我国经济发展中具有重要地位,目前我国的中小型超市数量多,地区分布广泛,行业分布跨度大。随着全球经济一体化的发展和电子商务的兴起,中小型超市之间的竞争将越来越激烈。网络及电子商务的迅猛发展突破了时间、空间的局限性,给中小型超市带来了更多的发展机会,同时也增大了超市行业间的竞争强度。这就要求中小型超市必须改变营业管理模式,提高运营效率。目前,我国中小型超市的信息化水平还很低。随着技术的发展,电脑操作及管理日趋简化,电脑知识日趋普及,同时市场经济快速多变,竞争激烈,超市行业采用电脑管理进货、库存、销售等
10、诸多环节也已成为必然趋势。1.1 研究课题的目的社会生活的现代化,使得市场的走向发生巨大变化,由于经济的发展,人民对生活的需求已经不再满足于丰衣足食的低度要求,许多人们往往不是单纯为满足生活必须去购买,而是凭着喜欢、意欲和感官去购买。如果一个商店能够打动顾客、吸引顾客,自然会顾客盈门,而近几年新兴产业中超级市场(supermarket)的现代化管理方式和便捷的购物方式,尤其是它轻松的购物环境,往往是打动顾客,吸引顾客的最主要的原因,且良好的周密的销售服务更是赢得信誉、吸引的顾客的优势所在。商品经济的高速现代化发展也促进了竞争,使一切不甘落后的商家都争先恐后地采用最新的管理方法来加强自己的竞争地
11、位。因为,超市经营者如果不掌握当今市场发展的这一走向,不能将超市现代化经营作为奴努力开拓的目标,就无法使经营活络、财源茂盛。现代化事业的发展,也使超市的管理数段发生前所未有的革命,计算机的运用正在发达国家的各类商店超市中普及。由于它能够准确记载和查询有关超市经营活动的大量数据,帮助超市经营者掌握和分析营销情况,及时作出正确决策,并且有利于商店内部财务、工资、人员、库存、销售情况等管理,因而大大提高了现代超市的管理水平。国外很多发达资本主义国家的有关人士都在开发超市管理系统,开发出很多大型的软件,由于本人能力有限,开发一个小型超市管理系统,它可以使我们国内新起毕业设计共 41 页,第 2 页小型
12、超市可以更好的操作。此系统的有减少差错,节省人力、减少顾客购物时间,增加客流量,提高顾客满意度等特点。我通过开发这个简单管理信息系统,巩固了以前所学的知识,提高了应用能力。1.2 研究课题的意义21 世纪,超市的竞争进入到了一个全新的领域,竞争不再是规模的竞争,而是技术的竞争、管理的竞争、人才的竞争。技术的提升和管理的升级是超市业的竞争核心。如何在激烈的竞争中扩大销售额、降低经营成本、扩大经营规模,成为超市经营者努力追求的目标。为了提高物资管理的水平和工作效率,尽可能杜绝商品流通中各环节中可能出现的资金流失不明现象,商品进销存领域迫切需要引进信息系统来加以管理,而商品销售管理系统是当前应用于超
13、市或者公司管理系统的典型代表。从消费者的角度来说,结帐时应该准备和快速,毕竟时间就是金钱。由于传统的超市收银管理给顾客和店主带来很多不便。针对这方面的缺陷,开发这个系统可以方便快捷地查出顾客结帐情况,商品信息情况,每天的售货情况,方便了对超市商品管理、人员管理,大大提高了超市的售货速度。进而加速了社会的发展速度,提高了人民的生活水平。总之,借助于信息系统可以大大提高超市的运作效率,通过全面的信息的采集和处理,不仅辅助提高了超市的决策水平,还可以迅速提高超市的管理水平,为降低经营成本,提高效率,增强超市扩张力,提供有效的技术保障。毕业设计共 41 页,第 3 页2 需求分析2.1 可行性研究系统
14、开始和可行性研究是为系统开发做前期准备 1。在对一个项目的开发之前,我们总是要对其进行一个可行性分析与需求分析,通过和指导老师的共同分析得出了可行性开发计划。对于需求分析我们作了如下调查分析的需求。2.1.1 技术可行性随着软件编程技术的不断增加,功能的不断加强,和网络技术的不断成熟,信息安全的不断完善以及开发工具的日益进步,采用计算机系统来管理超市要求数据的采集、更新能够完整、准确和及时,所以开发通用的超市收银系统已经完全可以做到。2.1.2 经济可行性因为通过网络传递销售信息,可以不受距离的限制,因此可以节约许多的人力和物力,方便管理,由此可以减少不必要的开支,同时该系统可以提高超市的销售
15、效率,即提高了超市的经济效益,所以从经济上是完全可行的。2.1.3 操作可行性本系统采用 Windows 图形界面,是大家熟悉的操作系统,对于用户只需要具有一般的计算机知识的人员都可以轻松上手。而且整个销售系统采用最友好的交互界面,简洁明了,不需要对数据库非常了解。由此,该系统的操作是可行的,有必要推广该系统。综合以上三方面,该系统具有很高的开发可行性,无论是从技术上经济上还是操作上。故此,可以设计该系统流程图,建立数据字典。2.2 需求分析对于大型超市信息管理系统来说,通常它会把员工人事管理系统也包括在内。由于现考虑的是小型超市,其可承担的研发支费也有限 2。所以在这个系统中,要实现的功能主
16、要如下:(1) 功能要求对库存产品进行资料管理和统计;对产品的进货单和产品的销售单进行录入管理和统计;对进货、销售、库存情况进行查询;对用户进行管理,具体为添加用户、删除用户、修改用户密码;对供应商基本信息的管理;对赢利状况分析,进行营业统计,按年月日及商品类别统计;毕业设计共 41 页,第 4 页(2) 数据精确度产品的进货单和销售单中,单价、金额采用浮点数,数量都取整数。(3) 时间特性该系统软件从启动到进入系统登录界面的时间正常情况下少于 5 秒,录入并更新数据的时间正常情况下少于 10 秒。(4) 适用性该管理系统软件适用于 Windows 2000/Windows XP 中文版下运行
17、。2.3 开发环境介绍该系统属于管理信息系统,管理信息系统(MIS,Management Information System )可以保存用户信息,通过对信息进行分析和处理,可以帮助用户制定计划、规范管理或提供决策依据。超市收银系统具有其特殊性,通常采用C/S结构,考虑到其为小型超市,所以在架构上面选择两层。2.3.1 C#介绍C sharp(又被简称为”C#”)是微软公司在 2000 年 6 月发布的一种新的编程语言。C#看起来与 Java 有着惊人的相似;它包括了诸如单一继承,界面,与 Java 几乎同样的语法,和编译成中间代码再运行的过程。但是 C#与 Java 有着明显的不同,它借鉴了
18、Delphi 的一个特点,与 COM(组件对象模型)是直接集成的,而且它是微软公司.NET windows 网络框架的主角 3。C#在带来对应用程序的快速开发能力的同时,并没有牺牲 C 与 C+程序员所关心的各种特性。它忠实地继承了 C 和 C+的优点。如果你对 C 或 C+有所了解,你会发现它是那样的熟悉。即使你是一位新手,C#也不会给你带来任何其它的麻烦,快速应用程序开发(Rapid Application Development,RAD)的思想与简洁的语法将会使你迅速成为一名熟练的开发人员。C#是专门为 .NET 应用而开发出的语言。这从根本上保证了 C#与.NET 框架的完美结合。在.
19、NET 运行库的支持下, .NET 框架的各种优点在 C#中表现得淋漓尽致。C#具有如下几个特点:(1) 简洁的语法在缺省的情况下,C#的代码在.NET 框架提供的“ 可操纵”环境下运行,不允许直接地内存操作。它所带来的最大的特色是没有了指针。C#只支持一个“.” ,对于我们来说,现在需要理解的一切仅仅是名字的嵌套而已。(2) 精心地面向对象设计C#具有面向对象的语言所应有的一切特性:封装、继承与多态性,这并不出奇。然而,通过精心地面向对象设计,从高级商业对象到系统级应用,C#建造广泛组件的毕业设计共 41 页,第 5 页绝对选择。在 C#的类型系统中,每种类型都可以看作一个对象。C#提供了一
20、个叫做装箱(boxing)与拆箱(unboxing)的机制来完成这种操作,而不给使用者带来麻烦。C#只允许单继承,即一个类不会有多个基类,从而避免了类型定义的混乱。C#中没有了全局函数,没有了全局变量,也没有了全局常数。一切的一切,都必须封装在一个类之中。你的代码将具有更好的可读性,并且减少了发生命名冲突的可能。(3) 与 Web 的紧密结合C#组件将能够方便地为 Web 服务,并允许它们通过 Internet 被运行在任何操作系统上的任何语言所调用。举个例子,XML 已经成为网络中数据结构传递的标准,为了提高效率,C#允许直接将 XML 数据映射成为结构。这样就可以有效的处理各种数据。(4)
21、 完整的安全性与错误处理语言的安全性与错误处理能力,是衡量一种语言是否优秀的重要依据。C#的先进设计思想可以消除软件开发中的许多常见错误,并提供了包括类型安全在内的完整的安全性能。内存管理中的垃圾收集机制减轻了开发人员对内存管理的负担。.NET 平台提供的垃圾收集器(Garbage Collection,GC )将负责资源的释放与对象撤销时的内存清理工作。(5) 版本处理技术C#提供内置的版本支持来减少开发费用,使用 C#将会使开发人员更加轻易地开发和维护各种商业用户。(6) 灵活性和兼容性如果需要,C#允许你将某些类或者类的某些方法声明为非安全的。如此就能使用指针、结构和静态数组。此外,它还
22、引进了模拟指针功能的-delegates,指代。C#不支持类的多继承,但是通过对接口的继承,你将获得这一功能。2.3.2 SQL Server2005 介绍Microsoft 公司的 SQL Server 是关系型网络数据库管理系统,它的工作环境为Microsoft Windows NT 系列或 Microsoft Windows98。SQL Server 与 Microsoft 公司的其它软件,如 Microsoft office 和 Microsoft Visual Studio 设计风格一致,并能相互配合。SQL Server 具有分布式数据库和仓库管理功能,支持客户机/ 服务器结构,并
23、能进行分布式事务处理和联机分析处理。SQL Server 具有强大的数据库管理功能,它提供丰富的管理工具以支持数据库的安全性管理、完整性管理和作业管理。SQL Server 还具有强大的网络功能,支持发布 Web 页面和接收电子邮件。 SQL Server 支持 ANSI SQL(标准 SQL) ,并将标准 SQL 扩展成为更加实用的 Transact-SQL4。使用 SQL Server 2005,开发人员通过使用相似的语言,例如微软的 Visual C# 毕业设计共 41 页,第 6 页.NET 和微软的 Visual Basic,将能够创立数据库对象。开发人员还将能够建立两个新的对象用户
24、定义的类和集合。在使用本地网络和互联网的情况下,在不同应用软件之间散步数据的时候,可扩展标记语言(XML)是一个重要的标准。 SQL Server 2005 将会自身支持存储和查询可扩展标记语言文件。从对 SQL 类的新的支持,到多活动结果集(MARS),SQL Server 2005 中的 ADO.NET 将推动数据集的存取和操纵,实现更大的可升级性和灵活性。2.3.3 C/S 介绍在网络连接模式中,除对等网外,还有另一种形式的网络,即客户机/服务器网,Client/Server。在客户机/服务器网络中,服务器是网络的核心,而客户机是网络的基础,客户机依靠服务器获得所需要的网络资源,而服务器
25、为客户机提供网络必须的资源。这里客户和服务器都是指通信中所涉及的两个应用进程(软件),所以有时要根据上下文判断 client 与 server 是指软件还是硬件。C/S 可以充分利用两端硬件环境的优势,将任务合理分配到 Client 端和 Server 端来实现,降低了系统的通讯开销 5。最简单的 C/S 体系结构的数据库应用,由两部分组成,即客户应用程序和数据库服务器程序。二者可分别称为前台程序与后台程序。运行数据库服务器程序的机器,称为应用服务器,一旦服务器程序被启动,就随时等待响应客户程序发来的请求;客户程序运行在用户自己的电脑上,对应于服务器电脑,可称为客户电脑。当需要对数据库中的数据
26、进行任何操作时,客户程序就自动地寻找服务器程序,并向其发出请求,服务器程序根据预定的规则作出应答,送回结果。在典型的 C/S 数据库应用中,数据的储存管理功能,是由服务器程序独立进行的,并且通常把那些不同的(不管是已知还是未知的)前台应用所不能违反的规则,在服务器程序中集中实现,例如访问者的权限,编号不准重复、必须有客户才能建立定单这样的规则。所有这些,对于工作在前台程序上的最终用户,是“透明”的,他们无须过问(通常也无法干涉)这背后的过程,就可以完成自己的一切工作。在客户服务器架构的应用中,前台程序可以变的非常“瘦小”,麻烦的事情,都交给了服务器和网络。在 C/S 体系的下,数据库真正变成了
27、公共、专业化的仓库,受到独立的专门管理。毕业设计共 41 页,第 7 页3 总体设计3.1 设计思想(1) 系统分成几个相对独立的模块,但这些模块都进行集中式管理。(2) 分层的模块化程序设计思想,整个系统采用模块化机构设计。作为应用程序有较强的可操作性和扩展性。(3) 合理的数据流设计,在应用系统设计中,相对独立的模块间以数据流相互连接,使各模块间的耦合性较低,方便系统运行,提高系统安全性。3.2 设计原则为了使本系统功能齐全完备,操作简便,最大限度的提高软件的质量,从而满足用户的实际需要,在设计开发过程中遵循了,如下原则:(1) 合法性原则:依据产品核算系统的工作规定以及要求,参照核算实际
28、的工作情况,进行诸如商品进货、销售等工作。(2) 实用性原则:适合产品信息管理工作的实际需求,并能够处理一些特殊情况的要求,此外,尽可能预留空间,以便扩充功能。(3) 准确性原则:对输入的相关资料建立检错机制,及时报错,使用户能够及时准确的输入合法资料(如类型匹配,长度不超限等) 。(4) 易操作原则:要求设计的系统功能齐全,接口友好,操作方便,必要的地方进行提示。(5) 源程序可读性原则:为了便于其它设计,维护人员读懂代码或以后的代码修改,软件升级维护,既可能做好代码注释工作。(6) 优化原则:为了达到优化的目的,合理的运用窗口,菜单,对象等的继承,自定义用户对象,事件,函数,减少不必要的重
29、复性代码,使程序简洁明了,也方便了将来的维护。(7) 安全性原则:该系统的管理员具有可设置登陆密码,修改密码的权限。经过前面的设计,我们对整个系统有了一个初步的认识,并对各个模块进行了功能分化。 3.3 功能模块和结构设计小型超市管理系统包括系统管理员、库存管理员、商品销售员三大角色,对应本系统中的权限,根据权限的不同,可操作的业务不同。本节将对小型超市收银系统进行总体设计,介绍系统的总体功能和模块划分。毕业设计共 41 页,第 8 页3.3.1 系统结构小型超市收银系统所包含的功能模块有:商品入库模块、商品销售模块、营业统计模块、商品信息模块、供应商信息模块、用户信息模块。系统功能结构图见图
30、 3-1。小型超市收银系统商品入库商品销售营业统计商品信息供应商信息用户信息图 3-1 系统功能结构图超市收银系统的业务流程图,如图 3-2 所示。否系 统 主 窗 体营 业 统 计 商 品 信 息 用 户 信 息供 应 商 信 息商 品 销 售商 品 入 库系 统 登 录是 否 登 录是图 3-2 系统业务流程图3.3.2 系统各功能模块定义(1) 商品入库模块该模块用于实现商品的入库管理,当供应商所供商品出现问题需退货时可以实现退货管理。另外用户还可以根据条件查询相关的入库记录。(2) 商品销售模块毕业设计共 41 页,第 9 页该模块用于实现商品售出、收银功能。顾客倘若对商品不满意还可以
31、进行退货处理。(3) 营业统计模块该模块实现商品销售情况及入库情况统计分析,让系统用户可以根据时间查询统计信息。(4) 商品信息模块该模块实现商品基本信息的管理,如商品的添加、修改、删除操作、条件查询。对于低于库存报警值的商品会显示出来。(5) 用户信息模块该模块实现用户基本信息的管理,含用户的添加、修改、删除,用户信息记录的浏览。(6) 供应商信息模块该模块实现供应商基本信息的管理,系统用户可以实现供应商信息的添加、删除、修改,条件查询以及查看供应商可提供的相关商品。3.4 数据库设计数据库在一个管理信息系统中占有非常重要的地位,数据库结构设计的好坏将直接对应用系统的效率以及实现的效果产生影
32、响。合理的数据库结构设计可以提高数据存储的效率,保证数据的完整和一致,同时,合理的数据库也将有利于程序的实现 6。设计数据库系统时应该充分了解用户各个方面的需求,包括现有的以及将来可能增加的需求。3.4.1 数据库的需求分析SQL Server 数据库的建立方法可以分成两个阶段,第一个阶段是根据要输入的数据性质,新增表并设置表的字段名称、数据类型和语句,第二个阶段是在表内输入数据。根据上述系统功能的分析,得出系统有如下需求信息:(1) 系统必须能够区别各种用户,如库存员、收银员。(2) 系统支持用户的增加、登陆。(3) 系统必须能够显示各种商品的信息,并允许用户使用搜索功能来查找自己所需要的商
33、品。(4) 系统必须能将所有商品信息进行分类。(5) 系统能支持用户将商品入库、退货。(6) 系统能支持用户将商品售出、退货。(7) 系统支持供应商信息的管理。毕业设计共 41 页,第 10 页(8) 系统支持营业情况的查询。经过上述功能分析和需求总结,设计如下的数据项和数据结构:(1) 用户,包括数据项:编号,用户名,密码,权限。(2) 商品类别,包括数据项:编号,商品名称。(3) 商品,包括数据项:商品编号(条形码),商品名称,类别,库存量、报警值,计量单位,规格,售价。(4) 供应商,包括数据项:名称,联系人,联系电话,传真,地址,合作起始时间。(5) 销售记录,包括数据项:编号,操作人
34、,商品编号,售价,售出数量,售出时间。(6) 进货记录,包括数据项:商品,供应商,操作人,进价,进货数量,进货时间。(7) 供货,包括数据项:供应商,商品,最新进价。3.4.2 数据库概念结构设计得到上面的数据项和数据结构后,就可以设计出系统中的各个实体以及他们之间的关系,为后面的逻辑结构设计打下基础。本系统根据上面功能分析和需求总结设计出的实体共有下面几个,下面分别列出本系统所使用到的各基本实体和各实体之间的联系。如图 3-3 所示: 毕业设计共 41 页,第 11 页图 3-3 实体联系(E-R)图3.4.3 数据库逻辑设计(1) 表设计将数据库的概念结构设计转换成关系模型,就得到了以下的
35、几张数据库中的表 7:下面分别介绍这些表。系统登录用户的基本信息保存在用户信息表里,其中对于用户编号,通过自增方式实现,无需用户手动编号,编号从 1000 起始。详细说明如表 3-1 所示。销 售 数 量售 价操 作 人商 品销 售 记 录N供 应 商商 品进 货 数 量 操 作 人进 价进 货 记 录进 货 时 间N名 称联 系 电 话 合 作 起 始 时 间地 址 传 真联 系 人 供 应 商销 售供 货1 进 货计 量 单 位报 警 值规 格商 品库 存 量类 别N1 1商 品 名 称包 含 商 品 编 号N供 货 记 录商 品供 应 商最 新 进 价用 户 名用 户 编 号密 码权 限
36、用 户 1商 品 类 别 类 别 名 称毕业设计共 41 页,第 12 页表 3-1 用户信息表(Users)序号 属性名 字段名 类型 长度 NULL 默认 备注1 编号 UserID int 4 主键自增,标识种子 10002 真实名字 UserName varchar 10 3 密码 UserPassword varchar 50 MD5 加密存储4 权限 UserRight varchar 10 商品种类繁多,可以划分为大范围的不同种类。对于这些种类,已事先划分并存储于数据库中,不需要用户自动添加。商品类别信息表如下表 3-2。表 3-2 商品类别信息表(GoodsType)序号 属性
37、名 字段名 类型 长度 NULL 默认 备注1 类别编号 TypeID tinyint 主键自增2 名称 TypeName nvarchar 10 商品信息表记载的是商品的详细信息,含商品编号、名称、类别、计量单位、规格、售价、库存量等等。具体的各字段属性说明和类型如下表 3-3。表 3-3 商品信息表(GoodsInfo)序号 属性名 字段名 类型 长度 NULL 默认 备注1 商品编号 GoodsID nvarchar 20 主键2 类型号 TypeID tinyint 3 名称 GoodsName nvarchar 50 4 计量单位 GoodsUnit nvarchar 5 5 规格
38、GoodsNorm nvarchar 20 6 售价 GoodsSellPrice smallmoney 7 库存量 GoodsNum int 4 08 报警值 AlarmNum int 4 09 备注 GoodsRemark nvarchar 100 描述信息入库记录表包含商品入库的相关信息,入库信息有入库时间、操作人、进库商品、商品数量等。每一笔商品的入库都对应一个编号,具有唯一性。在这里,对编号的处理就是用入库时的时间做编号。具体的各字段的属性说明和类型如下表 3-4 所示。毕业设计共 41 页,第 13 页表 3-4 入库记录表(StockInfo)序号 属性名 字段名 类型 长度 N
39、ULL 默认 备注1 编号 StockID varchar 20 主键,与时间相关2 商品编号 GoodsID nvarchar 20 外键3 供应商编号 CompanyID int 4 外键4 操作员 Operator int 4 外键5 进价 GoodsPrice smallmoney 6 数量 GoodsNum int 4 17 备注 Remark nvarchar 100 商品销售信息存储在销售记录表中,流水编号也采用时间作为编号,具有唯一性。各字段的详细情况见下表 3-5。表 3-5 销售记录表(SellInfo)序号 属性名 字段名 类型 长度 NULL 默认 备注1 编号 Sel
40、lID varchar 20 主键,与时间相关2 商品编号 GoodsID nvarchar 20 外键3 操作者 Operator int 4 外键4 售价 SellPrice smallmoney 5 数量 GoodsNum int 4 6 备注 Remark nvarchar 100 退货原因供应商供货价格表中记载的是供应商所可商品的信息,含商品编号、供货商编号、最新进价。各字段的详细信息见下表 3-6。表 3-6 供应商供货价格表(StockPrice)序号 属性名 字段名 类型 长度 NULL 默认 备注1 商品编号 GoodsID nvarchar 20 组合主键2 供应商编号 C
41、ompanyID int 4 组合主键3 最新进价 GoodsSellPrice smallmoney 供应商信息表记录的是供应商的基本信息,其中编号由系统自动编号,采取主键自增方式,编号始于 1000。各字段的详细信息见下表 3-7。毕业设计共 41 页,第 14 页表 3-7 供应商信息表(Company)序号 属性名 字段名 类型 长度 NULL 默认 备注1 编号 CompanyID int 4 主键自增,标识种子 10002 名称 CompanyName nvarchar 50 3 联系人 CompanyDirector nvarchar 10 4 电话 CompanyPhone n
42、varchar 20 5 传真 CompanyFax nvarchar 20 6 地址 CompanyAdd nvarchar 50 7 合作时间 HzDataTime datetime (2) 视图设计根据逻辑模型所设计出的各种数据表构成了完整的物理数据库。由于业务范围的限制,每一个用户不可能访问数据库系统中的所有数据表,所访问的只是数据表的一个子集。我们把一个用户能访问到的数据表集合称为一个视图(View) 8。视图是以一致和直观的方式提供给用户的数据形式。视图以这种形式给用户提供数据,一方面为了满足用户对数据访问的方便性、简洁性需要,使数据在视图中以更符合用户要求和喜好的形式展现出来,另
43、一方面,为了保证数据的一致性,最好不要把数据表直接提供给最终用户。该数据库中涉及到的视图有两个:视图 QuerySell,对应的 Transact-SQL 语句:SELECT dbo.SellInfo.SellID, dbo.SellInfo.GoodsID, dbo.GoodsInfo.GoodsName, dbo.GoodsType.TypeName, dbo.Users.UserName, dbo.SellInfo.SellPrice, dbo.SellInfo.GoodsNum, dbo.SellInfo.RemarkFROM dbo.GoodsInfo INNER JOINdbo.S
44、ellInfo ON dbo.GoodsInfo.GoodsID = dbo.SellInfo.GoodsID INNER JOINdbo.Users ON dbo.SellInfo.Operator = dbo.Users.UserID INNER JOINdbo.GoodsType ON dbo.GoodsInfo.TypeID = dbo.GoodsType.TypeID视图 QueryStock,对应的 Transact-SQL 语句:SELECT dbo.StockInfo.StockID, dbo.StockInfo.GoodsID, dbo.GoodsInfo.GoodsName
45、, dbo.GoodsType.TypeName, dbo.Company.CompanyName, dbo.Users.UserName, dbo.StockInfo.GoodsPrice, dbo.StockInfo.GoodsNum, dbo.StockInfo.Remark毕业设计共 41 页,第 15 页FROM dbo.StockInfo INNER JOINdbo.GoodsInfo ON dbo.StockInfo.GoodsID = dbo.GoodsInfo.GoodsID INNER JOINdbo.Users ON dbo.StockInfo.Operator = db
46、o.Users.UserID INNER JOINdbo.Company ON dbo.StockInfo.CompanyID = dbo.Company.CompanyID INNER JOINdbo.GoodsType ON dbo.GoodsInfo.TypeID = dbo.GoodsType.TypeID毕业设计共 41 页,第 16 页4 系统实现系统用 SQL Server2005 做后台数据库,进行基于.net 发平台的 WinForm 应用程序开发,基本实现其功能。以下将描述系统几个主要功能模块的运行和测试的结果。4.1 登陆系统模块当我们建立了一个完整的系统时,尤其对于管理
47、系统,对于进入每个系统的人员我们都要对他进行身份验证,我们当然不希望有任何人进入该系统进行恶意的破坏,对系统中的数据进行修改,维护该系统的系统管理员也不希望有任何麻烦,所以对系统进行安全保护显的很重要,无论对于谁,系统的安全问题是首要的 9。为了解决这个问题,有一个简单、实用,但是老套的方法,就是口令加密。在该小型超市收银系统中对口令的加密采取的是常用的 MD5 加密算法。在新增或修改用户信息时,存入数据库的是用户密码的 MD5 哈希值,在登录验证时根据用户输入的密码计算相应的 MD5 哈希值进行比较。加密方法:public static string EncryptMD5(string ol
48、dData)/将字符串转化为字节序列 Byte clearBytes = new UnicodeEncoding().GetBytes(oldData);/计算字节序列对应的 Hash 值Byte hashedBytes = (HashAlgorithm)CryptoConfig.CreateFromName(“MD5“).ComputeHash(clearBytes);/返回经 MD5 加密后的字符串return BitConverter.ToString(hashedBytes);在用户登录系统时,用户只需要输入分配的用户 ID,只要 ID 号正确就可以自动显示出相应的用户名。为了防止他人
49、获知用户的密码,增强系统的安全性,我们将待输入密码的文本框的 PasswordChar 设为*,当用户输入密码后,系统将对所输入的密码进行检查,只有当密码正确才可进入到系统主界面,否则系统会提示错误。登录界面如图 4-1 所示。毕业设计共 41 页,第 17 页图 4-1 登录界面图用户登录成功后,会记下登录该系统的用户的权限,权限的不同,进入主界面后可进行的操作而异,体现在控件的可响应用户的鼠标点击事件与否。主界面如图 4-2所示。由于该用户属商品销售中的收银员,可以看到他只具有商品销售的权限。图 4-2 系统主界面图4.2 商品信息模块商品基本信息管理模块,用户可以对商品信息加以管理,界面可交互性强,运行时的界面图如下图 4-3。其中红色显示为低于库存值,需要进货的商品。毕业设计共 41 页,第 18 页图 4-3 商品 基本信息 管理界面 图4.3 商品 入库 模块具 有库存管 理权限的 用户进行 商品入库操作时,需要输入商品编号,至于供应商可