POS超市收银系统Word文件下载.docx
《POS超市收银系统Word文件下载.docx》由会员分享,可在线阅读,更多相关《POS超市收银系统Word文件下载.docx(35页珍藏版)》请在冰豆网上搜索。
2.2需求分析3
2.3开发环境介绍4
3总体设计10
3.1设计思想10
3.2设计原则10
3.3功能模块和结构设计11
3.4数据库设计12
4系统实现19
4.1登陆系统模块19
4.2商品信息模块20
4.3商品入库模块21
4.4商品销售模块23
4.5营业统计模块27
4.6供应商模块28
4.7用户信息模块30
参考文献31
总结32
1绪论
随着现代科学技术的迅猛发展,人们的生活方式正发生着巨大的变化。
计算机技术已经渗透到各个领域,成为各个行业必不可少的工具。
特别是Internet技术的推广和信息高速公路的建立,使得IT产业在市场竞争中越发显示出其独特的优势。
科学技术是第一生产力,科学技术的发展让人类更加受益。
各类信息系统应用于各行各业,不但给管理上带来了极大的便利,而且还提高了工作效率。
中小型超市在我国经济发展中具有重要地位,目前我国的中小型超市数量多,地区分布广泛,行业分布跨度大。
随着全球经济一体化的发展和电子商务的兴起,中小型超市之间的竞争将越来越激烈。
网络及电子商务的迅猛发展突破了时间、空间的局限性,给中小型超市带来了更多的发展机会,同时也增大了超市行业间的竞争强度。
这就要求中小型超市必须改变营业管理模式,提高运营效率。
目前,我国中小型超市的信息化水平还很低。
随着技术的发展,电脑操作及管理日趋简化,电脑知识日趋普及,同时市场经济快速多变,竞争激烈,超市行业采用电脑管理进货、库存、销售等诸多环节也已成为必然趋势。
1.1研究课题的目的
社会生活的现代化,使得市场的走向发生巨大变化,由于经济的发展,人民对生活的需求已经不再满足于丰衣足食的低度要求,许多人们往往不是单纯为满足生活必须去购买,而是凭着喜欢、意欲和感官去购买。
如果一个商店能够打动顾客、吸引顾客,自然会顾客盈门,而近几年新兴产业中超级市场(supermarket)的现代化管理方式和便捷的购物方式,尤其是它轻松的购物环境,往往是打动顾客,吸引顾客的最主要的原因,且良好的周密的销售服务更是赢得信誉、吸引的顾客的优势所在。
商品经济的高速现代化发展也促进了竞争,使一切不甘落后的商家都争先恐后地采用最新的管理方法来加强自己的竞争地位。
因为,超市经营者如果不掌握当今市场发展的这一走向,不能将超市现代化经营作为奴努力开拓的目标,就无法使经营活络、财源茂盛。
现代化事业的发展,也使超市的管理数段发生前所未有的革命,计算机的运用正在发达国家的各类商店超市中普及。
由于它能够准确记载和查询有关超市经营活动的大量数据,帮助超市经营者掌握和分析营销情况,及时作出正确决策,并且有利于商店内部财务、工资、人员、库存、销售情况等管理,因而大大提高了现代超市的管理水平。
国外很多发达资本主义国家的有关人士都在开发超市管理系统,开发出很多大型的软件,由于本人能力有限,开发一个小型超市管理系统,它可以使我们国内新起小型超市可以更好的操作。
此系统的有减少差错,节省人力、减少顾客购物时间,增加客流量,提高顾客满意度等特点。
我通过开发这个简单管理信息系统,巩固了以前所学的知识,提高了应用能力。
1.2研究课题的意义
21世纪,超市的竞争进入到了一个全新的领域,竞争不再是规模的竞争,而是技术的竞争、管理的竞争、人才的竞争。
技术的提升和管理的升级是超市业的竞争核心。
如何在激烈的竞争中扩大销售额、降低经营成本、扩大经营规模,成为超市经营者努力追求的目标。
为了提高物资管理的水平和工作效率,尽可能杜绝商品流通中各环节中可能出现的资金流失不明现象,商品进销存领域迫切需要引进信息系统来加以管理,而商品销售管理系统是当前应用于超市或者公司管理系统的典型代表。
从消费者的角度来说,结帐时应该准备和快速,毕竟时间就是金钱。
由于传统的超市收银管理给顾客和店主带来很多不便。
针对这方面的缺陷,开发这个系统可以方便快捷地查出顾客结帐情况,商品信息情况,每天的售货情况,方便了对超市商品管理、人员管理,大大提高了超市的售货速度。
进而加速了社会的发展速度,提高了人民的生活水平。
总之,借助于信息系统可以大大提高超市的运作效率,通过全面的信息的采集和处理,不仅辅助提高了超市的决策水平,还可以迅速提高超市的管理水平,为降低经营成本,提高效率,增强超市扩张力,提供有效的技术保障。
2需求分析
2.1可行性研究
系统开始和可行性研究是为系统开发做前期准备[1]。
在对一个项目的开发之前,我们总是要对其进行一个可行性分析与需求分析,通过和指导老师的共同分析得出了可行性开发计划。
对于需求分析我们作了如下调查分析的需求。
2.1.1技术可行性
随着软件编程技术的不断增加,功能的不断加强,和网络技术的不断成熟,信息安全的不断完善以及开发工具的日益进步,采用计算机系统来管理超市要求数据的采集、更新能够完整、准确和及时,所以开发通用的超市收银系统已经完全可以做到。
2.1.2经济可行性
因为通过网络传递销售信息,可以不受距离的限制,因此可以节约许多的人力和物力,方便管理,由此可以减少不必要的开支,同时该系统可以提高超市的销售效率,即提高了超市的经济效益,所以从经济上是完全可行的。
2.1.3操作可行性
本系统采用Windows图形界面,是大家熟悉的操作系统,对于用户只需要具有一般的计算机知识的人员都可以轻松上手。
而且整个销售系统采用最友好的交互界面,简洁明了,不需要对数据库非常了解。
由此,该系统的操作是可行的,有必要推广该系统。
综合以上三方面,该系统具有很高的开发可行性,无论是从技术上经济上还是操作上。
故此,可以设计该系统流程图,建立数据字典。
2.2需求分析
对于大型超市信息管理系统来说,通常它会把员工人事管理系统也包括在内。
由于现考虑的是小型超市,其可承担的研发支费也有限[2]。
所以在这个系统中,要实现的功能主要如下:
2.2.1功能要求
对库存产品进行资料管理和统计;
对产品的进货单和产品的销售单进行录入管理和统计;
对进货、销售、库存情况进行查询;
对用户进行管理,具体为添加用户、删除用户、修改用户密码;
对供应商基本信息的管理;
对赢利状况分析,进行营业统计,按年月日及商品类别统计;
(1)数据精确度
产品的进货单和销售单中,单价、金额采用浮点数,数量都取整数。
(2)时间特性
该系统软件从启动到进入系统登录界面的时间正常情况下少于5秒,录入并更新数据的时间正常情况下少于10秒。
(3)适用性
该管理系统软件适用于Windows2000/WindowsXP中文版下运行。
2.3开发环境介绍
该系统属于管理信息系统,管理信息系统(MIS,ManagementInformationSystem)可以保存用户信息,通过对信息进行分析和处理,可以帮助用户制定计划、规范管理或提供决策依据。
超市收银系统具有其特殊性,考虑到其为小型超市,所以在架构上面选择两层。
2.3.1C++介绍
C++这个词在中国大陆的程序员圈子中通常被读做“C加加”,而西方的程序员通常读做“Cplusplus”,“CPP”。
它是一种使用非常广泛的计算机编程语言。
C++是一种静态数据类型检查的、支持多重编程范式的通用程序设计语言。
它支持过程化程序设计、数据抽象、面向对象程序设计、制作图标等等泛型程序设计等多种程序设计风格。
组成部分:
1、C子语言。
C++支持C语言的几乎全部功能,主要是c89的部分,在语法上与C语言仅有极微妙的差别。
2、面向对象的C++语言。
C++语言原本不具备面向对象的设计功能,然而随着面向对象编程的概念的提出以及如Java等语言的发展成熟,C++语言也开发出了支持面向对象功能的版本。
3、泛型编程语言。
C++强大(但容易失控的)模板功能使它能在编译期完成许多工作,从而大大提高运行期效率。
4、STL(C++标准模板库,StandardTemplateLibrary)。
随着STL的不断发展,它已经逐渐成为C++程序设计中不可或缺的部分,其效率可能比一般的native代码低些,但是其安全性与规范性使它大受欢迎。
特点:
C++设计成静态类型、和C同样高效且可移植的多用途程序设计语言。
C++设计成直接的和广泛的支援多种程序设计风格(程序化程序设计、资料抽象化、面向对象程序设计、泛型程序设计)。
C++设计成给程序设计者更多的选择,即使可能导致程序设计者选择错误。
C++设计成尽可能与C兼容,籍此提供一个从C到C++的平滑过渡。
C++避免平台限定或没有普遍用途的特性。
C++不使用会带来额外开销的特性。
C++设计成无需复杂的程序设计环境。
优点:
C++在一定程度上可以和C语言很好的结合,甚至目前大多数C语言程序是在C++的集成开发环境中完成的。
C++相对众多的面向对象的语言,具有相当高的性能。
C++引入了面向对象的概念,使得开发人机交互类型的应用程序更为简单、快捷。
很多优秀的程序框架包括MFC、QT、wxWidgets就是使用的C++。
2.3.2MySql介绍
MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQLAB公司。
在2008年1月16号被Sun公司收购。
而2009年,SUN又被Oracle收购。
MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内。
这样就增加了速度并提高了灵活性。
MySQL的SQL“结构化查询语言”。
SQL是用于访问数据库的最常用标准化语言。
MySQL软件采用了GPL(GNU通用公共许可证)。
由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。
1.使用C和C++编写,并使用了多种编译器进行测试,保证源代码的可移植性
2.支持AIX、FreeBSD、HP-UX、Linux、MacOS、NovellNetware、OpenBSD、OS/2Wrap、Solaris、Windows等多种操作系统
3.为多种编程语言提供了API。
这些编程语言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等。
4.支持多线程,充分利用CPU资源
5.优化的SQL查询算法,有效地提高查询速度
6.既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名
7.提供TCP/IP、ODBC和JDBC等多种数据库连接途径
8.提供用于管理、检查、优化数据库操作的管理工具
9.可以处理拥有上千万条记录的大型数据库
10.支持多种存储引擎
2.3.3QT介绍
Qt是一个1991年由奇趣科技开发的跨平台C++图形用户界面应用程序开发框架。
它既可以开发GUI程式,也可用于开发非GUI程式,比如控制台工具和服务器。
Qt是面向对象语言,易于扩展,并且允许组件编程。
2008年,奇趣科技被诺基亚公司收购,QT也因此成为诺基亚旗下的编程语言工具。
优势:
面向对象
Qt的良好封装机制使得Qt的模块化程度非常高,可重用性较好,对于用户开发来说是非常方便的。
Qt提供了一种称为signals/slots的安全类型来替代callback,这使得各个元件之间的协同工作变得十分简单。
丰富的API
Qt包括多达250个以上的C++类,还提供基于模板的collections,serialization,file,I/Odevice,directorymanagement,date/time类。
甚至还包括正则表达式的处理功能。
支持2D/3D图形渲染,支持OpenGL
大量的开发文档
XML支持
Webkit引擎的集成,可以实现本地界面与Web内容的无缝集成
但是真正使得Qt在自由软件界的众多Widgets(如Lesstif,Gtk,EZWGL,Xforms,fltk等等)中脱颖而出的还是基于Qt的重量级软件KDE。
QtCreator:
在发布Qt4.6的同时,作为Qt开发跨平台IDE的QtCreator也发布了更新版本。
QtCreator1.3和Qt4.6共同构成的QtSDK,包含了开发跨平台应用程序所需的全部功能。
QtCreator是一个用于Qt开发的轻量级跨平台集成开发环境。
QtCreator可带来两大关键益处:
提供首个专为支持跨平台开发而设计的集成开发环境(IDE),并确保首次接触Qt框架的开发人员能迅速上手和操作。
QtCreator包含了一套用于创建和测试基于Qt应用程序的高效工具,包括:
一个高级的C++代码编辑器上下文感知帮助系统可视化调试器源代码管理项目和构建管理工具
QtCreator在LGPL2.1版本授权下有效,并且接受代码贡献。
2.3.4嵌入式系统简介
嵌入式系统是“控制、监视或者辅助装置、机器和设备运行的装置(devicesusedtocontrol,monitor,orassisttheoperationofequipment,machineryorplants)。
从中可以看出嵌入式系统是软件和硬件的综合体,还可以涵盖机械等附属装置。
目前国内一个普遍被认同的定义是:
以应用为中心、以计算机技术为基础、软件硬件可裁剪、适应应用系统对功能、可靠性、成本、体积、功耗严格要求的专用计算机系统。
特定的应用程序
嵌入式系统一般由以下几部分组成:
嵌入式微处理器
外围硬件设备
嵌入式操作系统
1.系统内核小。
由于嵌入式系统一般是应用于小型电子装置的,系统资源相对有限,所以内核较之传统的操作系统要小得多。
比如Enea公司的OSE分布式系统,内核只有5K,而Windows的内核?
简直没有可比性。
2.专用性强。
嵌入式系统的个性化很强,其中的软件系统和硬件的结合非常紧密,一般要针对硬件进行系统的移植,即使在同一品牌、同一系列的产品中也需要根据系统硬件的变化和增减不断进行修改。
同时针对不同的任务,往往需要对系统进行较大更改,程序的编译下载要和系统相结合,这种修改和通用软件的“升级”是完全两个概念。
3.系统精简。
嵌入式系统一般没有系统软件和应用软件的明显区分,不要求其功能设计及实现上过于复杂,这样一方面利于控制系统成本,同时也利于实现系统安全。
4.高实时性的系统软件(OS)是嵌入式软件的基本要求。
而且软件要求固态存储,以提高速度;
软件代码要求高质量和高可靠性。
5.嵌入式软件开发要想走向标准化,就必须使用多任务的操作系统。
嵌入式系统的应用程序可以没有操作系统直接在芯片上运行;
但是为了合理地调度多任务、利用系统资源、系统函数以及和专家库函数接口,用户必须自行选配RTOS(Real-TimeOperatingSystem)开发平台,这样才能保证程序执行的实时性、可靠性,并减少开发时间,保障软件质量。
6.嵌入式系统开发需要开发工具和环境。
由于其本身不具备自举开发能力,即使设计完成以后用户通常也是不能对其中的程序功能进行修改的,必须有一套开发工具和环境才能进行开发,这些工具和环境一般是基于通用计算机上的软硬件设备以及各种逻辑分析仪、混合信号示波器等。
开发时往往有主机和目标机的概念,主机用于程序的开发,目标机作为最后的执行机,开发时需要交替结合进行。
2.3.5Linux简介
基本思想:
Linux的基本思想有两点:
第一,一切都是文件;
第二,每个软件都有确定的用途。
其中第一条详细来讲就是系统中的所有都归结为一个文件,包括命令、硬件和软件设备、操作系统、进程等等对于操作系统内核而言,都被视为拥有各自特性或类型的文件。
至于说Linux是基于Unix的,很大程度上也是因为这两者的基本思想十分相近。
多任务、多使用者:
与windows系统不同的,linux主机上可以同时允许多人上线来工作,并且资源的分配较为公平,比起windows的单人假多任务系统要稳定的多啰!
这个多人多任务可是unix-like上面相当好的一个功能。
使用者与群组的规划:
在linux的机器中,档案的属性可以分为『可读、可写、可执行』等参数来定义一个档案的适用性,此外,这些属性还可以分为三个种类,分别是『档案拥有者、档案所属群组、其它非拥有者与群组者』。
这对于项目计画或者其它计画开发者具有相当良好的系统保密性。
桌面环境:
在图形计算中,一个桌面环境(Desktopenvironment,有时称为桌面管理器)为计算机提供一个图形用户界面(GUI)。
这个名称来自桌面比拟,对应于早期的文字命令行界面(CLI)。
一个典型的桌面环境提供图标,视窗,工具栏,文件夹,壁纸以及像拖放这样的能力。
整体而言,桌面环境在设计和功能上的特性,赋予了它与众不同的外观和感觉。
3总体设计
3.1设计思想
(1)系统分成几个相对独立的模块,但这些模块都进行集中式管理。
(2)分层的模块化程序设计思想,整个系统采用模块化机构设计。
作为应用程序有较强的可操作性和扩展性。
(3)合理的数据流设计,在应用系统设计中,相对独立的模块间以数据流相互连接,使各模块间的耦合性较低,方便系统运行,提高系统安全性。
3.2设计原则
为了使本系统功能齐全完备,操作简便,最大限度的提高软件的质量,从而满足用户的实际需要,在设计开发过程中遵循了,如下原则:
(1)合法性原则:
依据产品核算系统的工作规定以及要求,参照核算实际的工作情况,进行诸如商品进货、销售等工作。
(2)实用性原则:
适合产品信息管理工作的实际需求,并能够处理一些特殊情况的要求,此外,尽可能预留空间,以便扩充功能。
(3)准确性原则:
对输入的相关资料建立检错机制,及时报错,使用户能够及时准确的输入合法资料(如类型匹配,长度不超限等)。
(4)易操作原则:
要求设计的系统功能齐全,接口友好,操作方便,必要的地方进行提示。
(5)源程序可读性原则:
为了便于其它设计,维护人员读懂代码或以后的代码修改,软件升级维护,既可能做好代码注释工作。
(6)优化原则:
为了达到优化的目的,合理的运用窗口,菜单,对象等的继承,自定义用户对象,事件,函数,减少不必要的重复性代码,使程序简洁明了,也方便了将来的维护。
(7)安全性原则:
该系统的管理员具有可设置登陆密码,修改密码的权限。
经过前面的设计,我们对整个系统有了一个初步的认识,并对各个模块进行了功能分化。
3.3功能模块和结构设计
小型超市管理系统包括系统管理员、库存管理员、商品销售员三大角色,对应本系统中的权限,根据权限的不同,可操作的业务不同。
本节将对小型超市收银系统进行总体设计,介绍系统的总体功能和模块划分。
3.3.1系统结构
小型超市收银系统所包含的功能模块有:
商品入库模块、商品销售模块、营业统计模块、商品信息模块、供应商信息模块、用户信息模块。
系统功能结构图见图3-1。
图3-1系统功能结构图
超市收银系统的业务流程图,如图3-2所示。
图3-2系统业务流程图
3.3.2系统各功能模块定义
(1)商品入库模块
该模块用于实现商品的入库管理,当供应商所供商品出现问题需退货时可以实现退货管理。
另外用户还可以根据条件查询相关的入库记录。
(2)商品销售模块
该模块用于实现商品售出、收银功能。
顾客倘若对商品不满意还可以进行退货处理。
(3)营业统计模块
该模块实现商品销售情况及入库情况统计分析,让系统用户可以根据时间查询统计信息。
(4)商品信息模块
该模块实现商品基本信息的管理,如商品的添加、修改、删除操作、条件查询。
对于低于库存报警值的商品会显示出来。
(5)用户信息模块
该模块实现用户基本信息的管理,含用户的添加、修改、删除,用户信息记录的浏览。
(6)供应商信息模块
该模块实现供应商基本信息的管理,系统用户可以实现供应商信息的添加、删除、修改,条件查询以及查看供应商可提供的相关商品。
3.4数据库设计
数据库在一个管理信息系统中占有非常重要的地位,数据库结构设计的好坏将直接对应用系统的效率以及实现的效果产生影响。
合理的数据库结构设计可以提高数据存储的效率,保证数据的完整和一致,同时,合理的数据库也将有利于程序的实现。
设计数据库系统时应该充分了解用户各个方面的需求,包括现有的以及将来可能增加的需求。
3.4.1数据库的需求分析
MySql数据库的建立方法可以分成两个阶段,第一个阶段是根据要输入的数据性质,新增表并设置表的字段名称、数据类型和语句,第二个阶段是在表内输入数据。
根据上述系统功能的分析,得出系统有如下需求信息:
(1)系统必须能够区别各种用户,如库存员、收银员。
(2)系统支持用户的增加、登陆。
(3)系统必须能够显示各种商品的信息,并允许用户使用搜索功能来查找自己所需要的商品。
(4)系统必须能将所有商品信息进行分类。
(5)系统能支持用户将商品入库、退货。
(6)系统能支持用户将商品售出、退货。
(7)系统支持供应商信息的管理。
(8)系统支持营业情况的查询。
经过上述功能分析和需求总结,设计如下的数据项和数据结构:
(1)用户,包括数据项:
编号,用户名,密码,权限。
(2)商品类别,包括数据项:
编号,商品名称。
(3)商品,包括数据项:
商品编号(条形码),商品名称,类别,库存量、报警值,计量单位,规格,售价。
(4)供应商,包括数据项:
名称,联系人,联系电话,传真,地址,合作起始时间。
(5)销售记录,包括数据项:
编号,操作人,商品编号,售价,售出数量,售出时间。
(6)进货记录,包括数据项:
商品,供应商,操作人,进价,进货数量,进货时间。
(7)供货,包括数据项:
供应商,商品,最新进价。
3.4.2数据库概念结构设计
得到上面的数据项和数据结构后,就可以设计出系统中的各个实体以及他们之间的关系,为后面的逻辑结构设计打下基础。
本系统根据上面功能分析和需求总结设计出的实体共有下面几个,下面分别列出本系统所使用到的