11.1课程设计的目的通过本次课程设计,使学生能够全面、深刻地掌握数据库系统的设计流程。根据在数据库原理课程中所学到的数据库理论知识,结合某个具体的实际需求,最终开发出一个较为实用的数据库系统。1.2课程设计的背景和意义1.2.1课程设计的背景20世纪90年代后期特别是近几年,我国的超市产业飞速发展,其经营模式更为复杂,旧的管理体制已经无法适应超市的发展,这就迫切的需要引进新的管理技术。超市的数据和业务越来越庞大,而计算机就是一种高效的管理系统,这就需要我们把超市的管理与计算机结合起来,从而超市管理系统应运而生。依靠现代化的计算机信息处理技术来管理超市,节省了大量的人力、物力,改善了员工的并且能够快速反映出商品的进、销、存等状况和各种反馈信息分析,使管理人员快速对市场的变化做出相应的决策,加快超市经营管理效率。1.2.2课程设计的意义“数据库课程设计”的设计思想旨在强调学生的实际编程能力的培养与创意灵感的发挥。为此,本课程结合学科特点,除了让学生掌握数据库原理的理论知识,还增加了需求功能让学生完成,并鼓励学生的创作出个性的程序,满足客户需求,与市场的实际项目相结合。学生对此热情高,实际收获大,效果好。通过课堂学习和参与相关项目设计,学生对书本支持有了深刻的理解,实践性教学取得了良好效果。21.3课程设计环境操作系统:Windowsxp开发软件:MicrosoftVisualStudio2005数据库:MicrosoftSQLServer20053第2章系统需求分析随着人们生活水平的不断提高,对于物质的需求也越来越高,而超市作为日常生活用品聚集的场所,随着全球各种超市的数目的不断增加,规模不断增大,其管理难度也相应的增加,而为了适应当今信息化发展的时代,一套完整的超市商品管理系统显得尤为重要。2.1问题的提出在信息化高速发展的今天,超市商品管理的信息化管理已成为必不可缺的一部分,但是目前的大多是超市商品管理系统应用难度较高,许多工作需要技术人员配合才能完成,角色分工不明确;改版工作量大,系统扩展能力差,应用时更是降低了灵活性,这就使得一套完善的、能够正常工作的商品管理系统应运而生。2.2可行性分析系统的可行性分析是对课题的通盘考虑,是系统开发者进行进一步工作的前提,是系统设计与开发的前提与基础。系统的可行性分析可以使系统开发者尽可能早的估计到课题开发过程中的困难,并在定义阶段认识到系统方案的缺陷,这样就能花费较少的时间和精力,也可以避免许多专业方面的困难。所以,系统的可行性分析在整个开发过程中是非常重要的。2.2.1经济可行性分析因为通过网络传递销售信息可以不受距离的限制,因此可以借阅许多的人力和物力,方便管理,由此可以减少不必要的开支,同时该系统可以提高超市的销售效率,即提高了超市的经济效益,所以从经济上完全是可行的。42.2.2技术可行性分析本系统采用基于Windows的图形用户界面,而该系统是大家熟悉的操作系统,对于那些有一般的计算机知识的人员就可以轻松上手。而整个超市管理系统采用最友好的交互界面,简介明了,不需要对数据库进行深入的了解。由此,该系统的操作是可行的,有必要开发该系统。综合以上三方面,该系统具有很高的开发可行性,无论是从技术上或者经济上还是操作上。因此,可以设计该系统的数据流程图,建立数据字典。2.3系统的设计目标本系统主要包括四大模块,分别是人事管理模块,销售管理模块,进货管理模块,库存管理模块。每个模块的功能如下:1.人事管理模块功能:(1)实现职工信息的查询;(2)实现职工信息的更新,包括增加、删除、修改功能;(3)实现供货商信息的查询;(4)实现供货商信息的更新,包括增加、删除、修改功能。2.销售管理模块功能:(1)进行前台的销售;(2)将前台的销售与后台的数据库联系起来。3.进货管理模块功能:(1)实现进货信息的查询;(2)实现进货信息的更新,包括增加、删除、修改功能。4.库存管理模块功能:(1)实现商品库存信息的查询;5第3章系统开发的技术背景3.1开发技术及运行环境3.1.1系统所采用的开发技术通过权衡对各种编程语言和数据库使用的熟练程度,本系统选用Eclipse8.1作为前台开发工具,后台数据库采用SQLServer2005,整体设计以软件工程思想为指导思想,力求开发一个实用性强、操作简单且功能完整的超市商品管理系统。3.1.2系统运行环境操作系统:WindowsXP数据库:MicrosoftSQLServer2005前台:MicrosoftVisualStudio20056第4章系统分析与总体设计4.1系统结构框架一般的超市商品管理系统,主要由五大模块组成,即商品信息管理模块,人事管理模块,销售管理模块,进货管理模块,库存管理模块,此系统也不例外,主要有此五大模块组成。图4-1系统功能结构图。图4-1系统功能结构图4.2系统功能设计系统功能设计是使整个系统能基本实现超市的进、销、存等管理功能,能让超市管理者更直观的了解超市的经营状况,以做出相应的经营决策。管理信息系统(MIS)就是要对这些资源建立正确的数据库,并进行信息的收集、传送、存储、编制成各种凭证、报表、台帐、图形等信息,同时对这些信息进行维护,通过实测超市的各种运行情况,并利用过去的历史数据预测未来的发展,从超市全局的角度出发进行决策,利用信息控制超市的行为,附注超市完成其目标。本系统主要包括四大模块,分别是人事管理模块,销售管理模块,进货管理模块,库存管理模块。每个模块的功能如下:71.商品管理模块功能:(1)实现商品信息的查询;(2)实现职工信息的更新,包括增加、删除、修改功能;2.人事管理模块功能:(1)实现职工信息的查询;(2)实现职工信息的更新,包括增加、删除、修改功能;(3)实现供货商信息的查询;(4)实现供货商信息的更新,包括增加、删除、修改功能。3.销售管理模块功能:(1)实现前台商品的销售;(2)将商品的销售信息与数据库联系起来。4.进货管理模块功能:(1)实现进货信息的查询;(2)实现进货信息的更新,包括增加、删除、修改功能。5.库存管理模块功能:(3)实现库存信息的查询;8第5章系统数据库设计5.1超市管理系统数据库E-R模型通过对超市管理系统分析,得出系统的E-R图。图5-1数据库E-R模型图。图5-1数据库E-R模型图5.2数据库表设计5.2.1职工信息表职工信息表(StaffBill)用于存储职工信息,职工编号为主键是唯一标识。表中各字段功能定义如表5-1所示。名称职工/用户职工编号供货日期进货日期电话地址供货商编号供货商进货进货单号商品编号名称价格商品姓名性别mnmn工资身份证号供货销售单号销售日期数量mn销售9中文字段名英文字段名字段类型长度主键/外键字段值约束职工编号staffIDchar6PNOTNULL姓名namenvarchar8NOTNULL性别sexnchar2NOTNULL类别kindnvarchar10NULL身份证号idCardvarchar18NOTNULL备注othersntext50NULL表5-1职工信息表(StaffBill)5.2.2用户登录表用户登录表(Users_Info)用于存储用户的基本登录信息。表中各字段功能定义如表5-2所示。中文字段名英文字段名字段类型长度主键/外键字段值约束帐号loginIDchar6P/FNOTNULL密码passWordchar6NOTNULL表5-2用户信息表(Users_Info)5.2.3商品信息表商品信息表(Goods_Info)用于存储商品的信息。表中各字段功能定义如表5-3所示。中文字段名英文字段名字段类型长度主键/外键字段值约束商品编号merchIDchar6PNOTNULL供货商号profferIDchar6FNOTNULL名称fullNamenvarchar80NOTNULL类别kindnvarchar8NULL单价unitCostmoney4NOTNULL备注othersntext50NULL表5-3商品信息表(Goods_Info)105.2.4供货商信息表供货商信息表(Sup_Info)用于存储供货商的信息。表中各字段功能定义如表5-4所示。中文字段名英文字段名字段类型长度主键/外键字段值约束供货商号SupplierIDchar6PNOTNULL名称Namenvarchar50NOTNULL联系人contactPersonnvarchar8NOTNULL联系电话phonevarchar12NOTNULL联系地址addressnvarchar50NOTNULL备注othersntext50NULL表5-4供货商信息表(Sup_Info)5.2.5进货信息表进货信息表(Buy)存储进货信息。表中各字段功能定义如表5-5所示。中文字段名英文字段名字段类型长度主键/外键字段值约束进货单号BuyIDchar6PNOTNULL商品编号GoodsIDchar6P/FNOTNULL供货商号SupplierIDchar6FNOTNULL进货价Pricemoney4NOTNULL数量Amountint4NOTNULL金额Summoney4NOTNULL进货日期Datedatetime8NOTNULL备注Remarkntext50NULL表5-5进货信息表(Buy)5.2.6销售信息表销售信息表(Sell)用于存储销售信息。表中各字段功能定义如表5-6所示。11中文字段名英文字段名字段类型长度主键/外键字段值约束销售单号SeelIDchar6PNOTNULL商品编号GoodsIDchar6P/FNOTNULL销售数量Amountint4NOTNULL销售日期Datedatetime8NOTNULL表5-6销售信息表(Sell)5.2.7库存信息表库存信息表(Stock)存储库存信息。表中各字段定义如表5-7所示。中文字段名英文字段名字段类型长度主键/外键字段值约束商品编号GoodsIDchar6P/FNOTNULL库存数量Amountint4NOTNULL表5-7库存信息表(Stock)5.3创建数据库(1)使用T—SQL语句创建超市商品管理系统数据库。CREATEDATABASEdb_SMMSONPRIMARY(NAME=N'db_SMMS',FILENAME=F:\SMMS\SMMS\\DataBase\db_SMMS.mdf',SIZE=3072KB,FILEGROWTH=1024KB)LOGON(NAME=N'db_SMMS_log',FILENAME=N'F:\SMMS\SMMS\DataBase\db_SMMS_log.ldf',SIZE=1024KB,FILEGROWTH=10%)(2)使用T—SQL语句创建库存表。CREATETABLEStock(GoodsIDvarchar(10)COLLATEChinese_PRC_CI_ASNOTNULL,AmountintNOTNULL,PRIMARYKEY(StockID),FOREIGNKEY(GoodsID)REFERENCEStb_Goods(GoodsID));(3)使用T—SQL语句创建库存视图。createviewv_StockSASSELECTtb_Stock.StockID,tb_Goods.GoodsName,tb_Stock.Amount,tb_Stock.RemarkFROMtb_StockINNERJOINtb_GoodsONtb_Stock.G12第6章系统功能模块实现6.1系统登录模块用户登录模块在本系统的首页。用户输入用户名和密码后,系统进行验证,验证通过进入程序的主界面。界面如图6-1所示。图6-1用户登录界面主要实现代码如下:publicboolVeri(stringtb_table,stringId,stringPwd){DataClass.MyMeansMyClass=newSMMS.DataClass.MyMeans();booljud=false;if(Id!=&&Pwd!=){SqlDataReadertemDR=