网上商城设计1目录1系统分析与设计.......................................................................................................21.1系统总体的功能需求.........................................................................................21.2用户接口模块.....................................................................................................31.3管理员接口模块................................................................................................42系统UML建模........................................................................................................62.1系统用例图........................................................................................................62.2系统的时序图和活动图....................................................................................93数据库设计.............................................................................................................113.1数据库的R-R图..............................................................................................113.2数据表设计.......................................................................................................1221系统分析与设计1.1系统总体的功能需求网上商城是个复杂的电子商务系统,它必须提供接口以供用户登陆并从中选购喜爱的商品,同时还提供系统的管理接口以供管理员和一般网站工作者处理客户订单并维护网站正常运行。系统的总体功能框架如图1所示:(1)用户接口模块。用户接口是网站用户使用商城系统的服务入口,所有在线用户都通过浏览器登陆网站,并进行一系列的查询,订购等操作。用户接口模块包括用户信息维护、商品查询、订购商品和订单维护4个部分。用户登陆后,用户的ID将会被保存在服务器的缓存(session)中,用户在系统中所做的操作都将被系统存储到数据库中,以供商家进行销售情况和销售走势分析。(2)管理员接口模块。这是系统提供给网站维护管理人员的接口。管理员接口模块包括商品信息维护、内部员工信息维护、订单处理、销售情况查询和报表维护5部分。网站的一般工作人员通常只有订单处理的权限,他们获得用户提交的订单,并根据库存情况来确定发货或者推迟发货。网站管理员具有最高级的权限,可以处理客户的订单,可以浏览网站商品的销售情况,及时做出经营调整战略,降低经营风险。(3)数据服务模块。数据服务模块是系统正常运行的基础,它包括客户的网上商城用户接口模块管理员接口模块数据服务模块图1系统总体功能需求图3查询订单的保存,网站工作人员的订单处理;销售情况的查询分析。1.2用户接口模块用户接口模块包括下图2所示的几个方面。(1)用户信息维护。每个想在该系统中购物的用户都必须先注册,注册时的用户名是用户的唯一标识。系统可以接受客户的个人信息,比如购物方面的喜好,经济能力等等。系统的后台程序会自动记录每个用户在登陆网站后进行的所有操作,包括查询和订购信息,这种信息对于系统管理员是珍贵的数据,系统会根据用户的查询记录判断该用户的喜好及用户的经济情况。(2)商品查询。商品查询模块可以根据商品的名称、种类、价格、厂家等条件进行组合查询,在商品查询结果列表中,用户可以进一步查看详细信息。商品查询功能如上图3所示。当用户已经登陆时。(3)订购商品。客户在根据查询后得到相应的商品列表后,可以选择自己需要的商品放进购物车。在订购商品后,系统会自动保存并更新购物车的订单信息,系统工作人员可以及时得到订单处理,根据情况选择发货或延时发货。用户所有订购商品记录都保存在系统数据库中供后台管理员分析,订购商品功能如下用户接口模块用户信息维护商品查询订购商品订购维护输入商品的查询条件到数据库中查询相应信息提供符合条件的商品列表图2用户接口模块图3商品查询功能4图4所示。(4)订单维护。客户订购商品后可查询其订单的状态(包括处理中、发货中、缺货中和已完成),可以对订单进行添加、删除和修改操作。客户的订单维护信息也被保存在系统数据库中供管理员分析。订单维护功能如下图5所示。1.3管理员接口模块管理员接口包括图6所示的几个方面。管理员接口模块是系统管理员使用的核心模块,是整个商城系统正常运行的基础。输入订货商品更新该用户的订单生成新的客户订单图4订购商品功能输入要更改的信息更新该用户的订单生成新的客户订单图5订单维护功能管理员接口模块商品信息维护内部员工信息维护订单处理销售情况查询报表维护图6管理员接口模块5(1)商品信息维护,系统管理员登陆后可以对系统所有商品进行维护,包括商品的价格调整,商品的描述信息更新,新商品的加入和过期商品的删除等。系统的后台程序可以根据商品的销售情况提供给管理员一份详细的分析报告。管理员可以根据这份报告对热门书进行各方面的调整。这些方案都是根据数据库里记录的客户的查询、订购信息来决定的。商品信息维护如图7所示。前提条件:管理员已经登陆。(2)内部员工信息维护。系统管理员登陆后可以对内部员工信息进行维护,包括员工个人信息的更新,员工权限更改等等。系统涉及的使用者包括系统管理员和普通员工,普通员工一般只拥有订单处理的权限。但管理员可以设置员工的权限,比如增加报表打印权限。内部员工信息维护功能如图8所示。(3)订单处理。订单处理一般是普通员工的工作,用户在订购商品后,系统会及时更新其订单,普通员工登陆后,可以获得未处理的订单,并根据库存情况发货或者延迟发货。客户在查询商品时显示商品的库存情况,但管理员并不希望显示某商品的库存量为零,这样可能会失去一部分客户源。所以在库存不足的情况下,要求一般员工选择延时发货或拒绝订单。订单处理功能如图9所示。输入要更改员工的信息把更新信息保存到数据库生成新的员工信息图8内部员工信息维护功能输入要更改商品的信息把更新信息保存到数据库生成新的商品信息图7商品管理维护功能6前提条件:管理员或者普通员工已经登陆。(4)销售情况查询。销售情况查询为企业管理者提供了很重要的参数。管理员登陆后,可以得到详细的销售情况列表,并及时更新热门的商品信息(如排列位置等)。由于本功能涉及企业的经营信息,考虑到商业机密,所以需要管理员级别的用户才能使用本模块。销售情况查询功能如图10所示。(5)报表维护。报表维护提供查询结果的打印输出功能,如图11所示。2系统UML建模2.1系统用例图用IBM公司的RationalRose完成系统UML建模,如下图13至图18所示。输入所需数据的条件根据条件到数据库中查询打印查询结果图11销售情况查询功能输入查询条件根据条件到数据库中查询给出详细的查询结果图10销售情况查询功能输入订单处理结果把处理结果保存到数据库更新客户订单信息图9订单处理功能7图13系统管理的用例图8图14系统用户用例图92.2系统的时序图和活动图图15顾客订购时序图10图16顾客删除订单时序图图17管理员处理订单时序图11图18购买商品活动图3数据库设计3.1数据库的R-R图用MicrosoftVisio作出的系统E-R图如图19所示。12图19数据库的E-R图3.2数据表设计数据表的设计如下:(1)商品信息表product。(2)分类信息表sort。(3)用户基本信息表user。(4)订单信息表order。(5)订单条目描述表entry。(6)系统管理员信息表admin。分别如下表1至表6所示。表1商品信息表字段名类型长度是否允许为空是否键描述proIdint10否主键产品编号proNamevarchar60否否产品名saleCountint4否否销售数量13imagevarchar100是否图片路径pricevarchar40否否成本价格salePricevarchar40否否销售价格decriptmediumtext是否产品介绍salaDatedate是否销售时间sorIdInt4否外键产品分类编号表2分类信息表字段名类型长度是否允许为空是否键描述sorIdint4否主键产品分类编号sorNamevarchar40否否分类名表3用户基本信息表字段名类型长度是否允许为空是否键描述userIdint10否主键会员编号usernamevarchar20否否会员名passwordvarchar30否否密码realNamevarchar20是否真实姓名telvarchar40是否电话addressvarchar200是否地址zipvarchar8是否邮政编码emailvarchar50是否电子邮件表4订单信息表order字段名类型长度是否允许为空是否键描述orderIdint10否主键订单编号14orderNovarchar50否否生成订单的编号userIdint10否外键会员编号sendNamevarchar40否否收货姓名sendAdressvarchar200否否收货地址sendZipvarchar8否否收货邮编sendTelvarchar40否否收货人电话paymentvarchar20否否付款方式menovarchar200否否备注说明timedatetime否否订单生成时间tagInt4否否订单处理标记表5订单条目描述表entry字段名类型长度是否允许为空是否键描述entryIdint10否主键描述编号orderIdInt10否外键订单编号proIdInt10否外键产品编号pricevarchar20否否对应价格countInt4否否订购数量表6系统管理员信息表admin字段名类型长度是否允许为空是否键描述adminIdint4否主键管理员编号adminNamevarchar40否否分类名passwordvarchar30否否密码permissionsInt1否否权限