图书销售管理及系统设计管理知识分析.docx
四川师范大学本科毕业设计四川师范大学本科毕业设计 图书销售管理系统的设计与实现学生姓名学 号所 在 系计算机科学与技术系专业名称计算机科学与技术班 级指导教师四川师范大学二一二年五月图书销售管理系统的设计与实现 学生: 指导教师:内容摘要:随着各企业业务量的不断扩增,利用信息技术处理业务已经占据管理的核心地位,在其中扮演着重要的角色。而今图书的管理与销售的传统手工的管理模式严重滞后了本行业的前进脚步,所以,利用计算机提供的强大功能来进行管理是必然的结果。为了实现销售业务的信息化管理,图书销售行业迫切地需要开发出专业的销售管理系统。因此,图书销售管理系统有着广阔的应用前景和实际价值。为建立一套完善的图书销售管理系统,可以实现图书销售行业管理的自动化、智能化,提高管理工作效率,保证信息的准确与规范,减少管理人员工作量。图书销售管理系统能帮助管理人员快速方便的查找、统计当前图书的库存与进出货情况,为进货提供依据,让图书销售与管理真正做到科学、合理的规划、系统和高效的管理。为了更好的适应当前书店的销售需求,缓解手工管理存在的弊端,图书销售管理系统应运而生,改系统将提供一个操作方便,界面友好,功能强大的图书管理系统为工作提供全方位的服务。关键词:图书销售 管理系统 ASP.NET Book Sales Management System design and ImplementationAbstract: With the business of enterprise constantly amplification, using the information technology processing business have dominated the central position of the management, in which the play an important role. Now the books management and sales of the traditional manual management mode the serious lag of this industry steps forward, therefore, the use of a computer to provide the strong function of management is the inevitable result In order to achieve the sales information management, a book sales industry in urgent need of the professional development of sales management system. Therefore, book sales management system has broad application prospects and practical value. To set up a set of perfect book sales management system can realize the book sales industry management of automation, intelligent, and improve the management efficiency, guarantee the accuracy of information and the standard, reduce the management work. Book sales management system can help management personnel of quick and convenient search, the statistics of the book inventory and into the shipment, and to provide basis for purchase, get the sales and management really do scientific and reasonable planning, system and high efficient management. In order to adapt to the present bookstore sales demand, alleviate the deficiencies of the manual management, book sales management system came into being, changing the system will provide a convenient operation, friendly interface, powerful books management system management system for work provides the omni-directional service.Key words: Book Sales management system ASP.NET 目 录前言11相关开发工具21.1 ASP.NET技术21.2 ADO.NET技术31.3 数据库技术51.3.1 SQL SERVER数据库51.3.2结构查询语言(SQL)51.3.3系统的配置62系统总体分析62.1 需求分析62.2系统简介72.3系统功能模块划分82.4系统设计分析82.4.1 图书信息管理82.4.2 员工信息管理82.4.3 图书进货管理92.4.4 图书销售管理92.4.5 图书库存管理102.4.6 系统管理113数据库结构的设计与实现113.1 数据表的创建114系统的具体设计与实现144.1 类与方法144.2 主页面设计154.3 图书信息管理模块174.4 员工信息管理模块194.5 图书进货管理模块 销售管理模块214.6 图书销售管理模块234.7 图书库存管理模块255.8 系统管理模块275结束语28参考文献:31V四川师范大学本科毕业设计图书销售管理系统的设计与实现前言随着信息技术的膨胀以及现在工作节奏的加快,得以使架构的图书销售系统发展前景很可观。计算机管理系统的介入使得整个图书销售行业的管理过程变得十分简单和迅速,从而在一定程度上提高了图书的销售数量,减轻了库存挤压,降低了图书管理的效率与保密性风险,满足图书信息系统对数据管理的要求。合理安排图书的库存和销售,必将是提高图书销售行业经济效益的主要手段之一。鉴于此,我本次选择的毕业设计是图书销售管理系统,我认为建立一个完善的图书销售管理系统将在此领域发挥着很重要的作用,同时也能在改善图书销售管理人员的工作效率低,查找与更新所带来的不便。之后也将在管理书籍进出货的能力上都能够有很大的改观。 作为一种新的程序语言,ASP.NET是一种全新的面向对象的程序语言,简化了应用程序的开发,为开发者与操作者都带来了极大的方便。而SQL.Server2005能建立起后台数据一致性和完整性强,数据安全系数高的库,同时具有高性能的数据访问技术。因此采用ASP.NET2005与SQL.Server2005数据库技术相结合开发图书销售管理软件,可以划分为这样几个模块:图书信息管理、员工信息管理、图书进货管理、图书销售管理、图书库存管理、系统管理等,整套系统目的为实现具有高安全性、可靠性等优点而服务,能够应用于各类图书销售行业的管理,它的内容将对管理者与决策者都至关重要。本课题的目的是在于研究图书销售管理系统的开发途径与应用方式,探讨一种基于Web平台的自包含,自描述、模块化的应用特点,做相关的研究与分析并且付出实践,从而体现了基于模块设计、三层结构应用、组件重用等的技术特点,主要目标是为了在现存的各式异构平台上建立一个与平台、语言无关的通用的技术层次,为今后的企业级开发应用积累经验。对于企事业单位来说,利用计算机支持企业高效率完成销售管理的日常事务,是适应现代企业制度要求、推动企业销售管理走向科学化、规范化的必要条件;而销售管理部分是企业管理中一项琐碎、复杂而又十分细致的工作,在销售的各个环节中不允许出现任何错误,如果实行手工操作,每月都会耗费企业工作人员大量的时间和精力,同时计算机具有手工管理无法比拟的优点.例如: 查找方便、检索迅速、存储量大、可靠性高、保密性好、成本低、寿命长等。这些优点能够极大的提高管理效率,也是企业的科学化、正规化管理,与世界接轨的重要条件。这就迫切需要标准、高效率的计算机管理方式引导其发展,通过计算机管理该企业的日常运作,给管理者以决策参考的模型,来不断改进完善企业管理水平,提高工作效率。另外,现在客户期望值越来越高,客户需要更好的服务(产品及个性化服务)。企业的竞争已逐渐从产品竞争转变为服务竞争,因此中小企业要发展就必须需要进一步优化业务流程以提高企业竞争力。因此,加强销售管理是企业发展的必然,通过计算机来完成大量的人工操作,真正达到合理和充分利用现有资源,减轻工作压力。因此,开发一个销售管理系统是很有必要的,具有其特有的技术意义和管理意义。近年来,国内外对此销售管理类系统的开发与研究也是很有实用性的,基本上能根据各企业的自身特点,来进行销售方面的管理,同时,该类系统结合实际需求不断的向前发展, 争取通过技术的改善,能普遍运用于同类行业中,这才是信息技术发展的前沿潮流。今后此类软件将会向面向于大众的条码销售管理系统发展,现阶段,伴随物流及管理信息化、网络化的发展,应用条码技术进行销售管理、实现销售作业自动化,将是一个必然的发展趋势。随着信息化技术的不断提高和应用普及,更多的商品拥有自己的条码,而且,使用条码化工作代替传统作业模式,大大的减少手工输入所带来的统计性错误,这样不但提高了作业效率,而且还能确保资料准确性,并减少因人为失误而造成的损失。随着计算机的普遍应用,图书产业的相继发展壮大,图书销售行业需要实现进销存的计算机管理来提高管理效率是势在必行的,图书管理系统拥有着广泛的市场应用前景。行业的快速发展必将导致竞争愈演愈烈,要想在激烈的市场竞争中处于不败之地,就必须加强企业内部管理,提高运营效率。而图书种类繁多,销售模式特殊,业务量繁重,单凭手工记帐已经很难适应工作需要。图书作为一个与人们工作、生活和学习各个方面都不能分开的特殊商品,在人们生活水平日益提高的同时,它的地位也越来越重要。因此,开发一套好的图书销售管理软件已成为一个刻不容缓的课题,鉴于此本系统应时而生。所完成的图书销售管理系统软件是一功能比较完善的数据管理性软件,具有数据操作方便、高效、迅速等优点。该软件采用了功能强大的数据库软件开发工具,具有很好的可移植性,可在应用范围较广的WINDOWS系列操作系统上使用。另外,本系统还可通过访问权限控制以及数据备份功能,确保数据的安全性。1相关开发工具1.1 ASP.NET技术本系统的开发采用的开发技术是ASP.NET。Microsoft Visual Studio .NET是Microsoft公司新一代软件开发平台,也是.NET FrameWork的重要产品。ASP.NET作为 .NET的组成部分之一,是Internet和Intranet开发Web应用程序的新一代开发工具,正被程序员们广泛的使用。在ASP.NET中,所有Web客户端都通过Microsoft Internet信息服务(IIS)与ASP.NET应用程序通信。IIS对客户端的请求进行解密并验证请求是否合法。如果请求合法,则IIS会查找所请求的资源(如ASP.NET应用程序)。当客户已被授权,IIS会将客户请求通过进程传到ASP.NET运行引擎,然后返回适当的资源。ASP.NET是 Active Server Page 的下一个版本,也是一种建立在通用语言上的程序构架,能被用于一台Web服务器来建立强大的Web应用程序。ASP.NET提供许多比现在的Web开发模式强大的优势。ASP.NET是把基于通用语言的程序在服务器上运行。不像以前的ASP即时解释程序,而是将程序在服务器端首次运行时进行编译,如此,当然比ASP一条一条的解释强很多。1.2 ADO.NET技术ActiveX Data Objects (ADO) 是微软提供给网页开发者在网页中存取数据库的最新技术,同时它也是ASP内置的重要组件。它被设计用来同新的数据访问层OLE DB Provider一起协同工作,以提供通用数据访问。OLEDB是一个低层的数据访问接口,用它可以访问各种数据源,包括传统的关系型数据库,以及电子邮件系统及自定义的商业对象。最重要的三个ADO.NET对象是Connection, Command和 Recordset. 本文将主要介绍Connection与Recordset这两个对象。每个Connection的属性定义了与数据源的连接。Recordset对象用来接收来自数据源的数据。Recordset可以与Connection一起使用,先建立一个连接,然后获取数据。尽管如此,Recordset也可以被单独创建,其Connection参数可以在Open属性定义。ADO.NET主要目的是为了存取或修改数据源数据、或增加数据到指定数据源,数据源不仅包括数据库,而且包括dBase、Acces、Foxpros、Excel或文本文件等一些小型的数据表,所以,只要是ODBC驱动程序所能存取的数据源皆是ADO存取的对象。ADO.NET主要是由Connection对象、Recordset对象、Command对象、Parameter对象、Property对象、Field对象及Error对象等七个对象与Fields数据集合、Parameters数据集合、Properties数据集合及Errors数据集合等四个数据集合所组合而成。ADO.NET提供的七个对象及其功能如下:a Connection对象负责与指定的数据源进行连接,它还可以通过事物(Transaction)来确保在事物中所有的数据源变更的全部成功。b RecordSet对象负责浏览和操作从数据库取出的数据,换言之,RecordSet对象就象是一个二维的数组,而每个数剧列包含一个或多个数据字段,即Field对象。c Command对象负责对数据库提供请求,也就是传递指定的SQL指令。这些命令通常包括INSERT(增加记录)、DELETE(删除记录)、UPDATE(更新记录)等。此外,也可以通过Command对象对数据库发出数据定义语言,例如CREATE TABLE(建立数据表)、DROP TABLE(删除数据表)或ALTER TABLE(修改数据表结构)等。d Parameter对象是负责传递Command对象所需要的SQL命令参数。e Property对象指的是ADO的各项对象属性值,也就是每个ADO对象都会有一组描述和控制对象行的属性。f Field对象表示指定RecordSet对象的数据字段。g Error对象是负责记录连接过程所发生的错误信息。ADO.NET提供的四个数据集合:a Connection对象包含Errors数据集合,在Errors数据集合中包含数剧源响应失败时所建立的Error对象。b Command对象包含Parameters数据集合,在Parameters数据集合中包括Command对象所有的Parameter对象。c RecordSet对象包含Fields数据集合,在Fields数据集合中包含RecordSet对象的所有Field数据字段对象。ADO.NET关系图如图图1.2-1 Activex Data Object关系图1.3 数据库技术1.3.1 SQL SERVER数据库数据库(Database)是一系列信息资源的集合。在一个数据库中,与一个项目有关的所有信息都可以叫做一条记录(Record)。每一条记录都由一系列的字段组成的。一系列记录的集合就构成了数据表格。简单的平面文件数据库信息存储非常有限,并且随着公司信息量的不断增加,要求信息存储的高安全性和随时调用的速度性都很,而关系型数据库却能包含数以百万计甚至上亿的记录,并可以利用复杂的标准对这些记录进行操作,例如排序和统计。把它们叫做“关系型”数据库,是因为需要拥有一个丰富的服务集合及数据的交互作用的平台来建立特定的链接关系。关系型数据库的优点在于:通过将一个表格中的字段与另一个表格中的字段联系起来,两个表格之间的信息可以相互调用,可以避免信息的重复记录,也可以避免管理上的混乱。Microsoft SQL Server是由微软Microsoft研制的关系型大型数据库管理系统。它具有独立于硬件平台、抢占式多任务管理、对称的多处理器结构、完善的安全系统和容错功能,并具有易于维护导入导出数据方便性能稳定等特点。1.3.2结构查询语言(SQL)SQL是结果化查询语言(Structured Query Language),它是现在最为成功和广泛使用的关系型数据库应用语言,由IBM在七十年代开发出来的,实现了关系型数据库中的信息检索。1992年制定了SQL标准SQL-92,它的全名是“International Standard ISO/IEC9075:1992, Database Language SQL”。SQL标准的确定使许多大型数据库厂家采用SQL语言作为其数据库检索语言。利用SQL语言,可以查询和管理自己的数据库。SQL语言主要提供四种功能:数据查询(Query)主要是利用Select命令进行各种信息的查询和数据定义(Definition);数据操纵(Manipulation)主要包括数据添加(Insert)、数据修改(Update)和数据删除(Delete)和数据控制(Control)。1.3.3系统的配置一个Web站点可以有多个应用程序运行,而每一个应用程序用唯一URL来访问,所以首先利用IIS开发应用程序的目录为“虚拟目录”。各个应用程序的“虚拟目录”可以不存在任何物理上关系。所以要运行该系统还需要将工程文件考入“C:Interpubwwwroot”目录下,然后在IIS中建一个“虚拟目录”,并命名为“BookSalesManagementSystem”。本系统采用的Microsoft SQL Server2005作为数据库服务器,所以还要打开“企业管理器”把以下两文件“BookSell_Data.MDF与BookSell_Log.LDF”附加到数据库中。配置系统的Web.config,.NET平台提供了一个统一的web开发平台,新建一个空白解决方案,在解决方案中自动生成一个Web.config,在这里面还要设置数据库连接信息,添加如下语句:<appSetting><add key=”ConnectionString” value=”sever=:Database=BookSell;uid=password=123456”/> </appSetting>2系统总体分析2.1 需求分析使用图书管理系统能够在很大程度上实现业务流程的信息化,让管理员时刻都能掌握图书的销售、采购、库存等情况。从而提高管理效率,提升企业市场竞争力。从目前图书销售行业的发展来看,图书销售管理系统首先需要满足以下几方面的需求:管理员对销售员工的需求情况能做出全面的掌握,及时得到历史销售记录。图书管理系统应具有方便的数据输入性能、良好的人机交互界面,应尽量减少汉字及其重复输入。管理员能够通过计算机增加图书库存。能够快速实现对各类图书的单项入库、销售及库存数据信息的查询,并且还能实现对某一种商品或者全部商品在某一时间的统计查询。把目前基本上是“静态”的图书库存管理变为“动态”管理,以便随时提供图书库存动态信息,从而达到减少库存,加速资金周转的目的。在图书管理销售管理系统,管理员对系统管理的示意图如图2.1-1所示。管理员员工管理图书管理进货管理销售管理库存管理系统管理图2.1-1 管理员对系统管理在图书管理销售管理系统,销售员工对系统操作的示意图如图2.1-2所示。销售员工图书库存查询修改个人密码图书库存报警图书信息查询图书销售个人业绩查询图2.1-2 员工对系统应用2.2系统简介图书销售管理系统是依照市场调查和管理学的理念,结合图书销售管理行业的特点,利用计算机实现便捷式管理系统。利用该图书销售管理系统可以使管理员快速的统计、查询任何时间内的图书的进书信息,然后根据读者的需求进一步调整图书的库存数量、上架比例。最终目的是在最短时间内。了解市场发展趋势、作出科学合理的决策、赢得最大的社会效益和经济效益。2.3系统功能模块划分本系统功能上主要分为6个模块:图书信息管理、员工信息管理、图书进货管理、图书销售管理、图书库存管理及系统管理。图书信息管理:添加图书类别、图书信息维护、添加图书信息。员工信息管理:添加员工信息、员工信息维护。图书进货管理:图书进货登记、图书进货查询、进货退货登记、进货退货查询。图书销售管理:图书销售查询、员工业绩查询、顾客退货办理、图书退货查询。图书库存管理:图书库存查询、图书库存盘点、图书库存报警。系统管理:供应商管理、修改密码、关于系统。2.4系统设计分析2.4.1 图书信息管理作为一款图书销售管理系统,图书信息的管理是其中不可或缺的一部分,主要包括图书信息的添加、添加图书类别、图书信息维护。系统设置模块的操作流程如图2.4.1-1所示。图书信息管理添加图书信息图书信息维护退出登录添加图书类别图2.4.1-1 管理员对图书信息管理操作的流程图2.4.2 员工信息管理员工信息管理是指管理员对销售员工的一些基本信息进行维护,其中,包括添加员工信息、员工信息维护等信息。员工信息管理模块的操作流程如图2.4.2-1所示。员工信息管理添加员工信息员工信息维护退出员工信息管理图2.4.2-1 员工信息管理模块的操作流程图2.4.3 图书进货管理通过图书进货管理模块的操作,就可以对进书日期、结算方式、进书数量、应付金额等相关内容进行具体的管理,使图书交易不论在数量上还是在现金结算上都显得十分明确。图书进货管理图书进货登记图书进货查询进货退货登记进货退货查询退书进货管理图2.4.3-1 图书进货管理模块的操作流程图2.4.4 图书销售管理通过对销售的管理可以更加明确哪些图书的销量多,哪些图书的销量少。由于一些图书未能如期销售或销售量降低,此时需要对这些图书进行销售退货,在退货时,应记录所退货的详细信息,以便在以后的管理和查询中能够如实的反映销售情况。图书销售管理员工业绩查询顾客退货办理图书退货查询图书销售查询退书图书销售管理图2.4.4-1 销售管理的模块操作流程图2.4.5 图书库存管理通过图书库存管理可以轻松的查询到图书库存情况,相应的系统还可设置图书报警,当图书库存到达设定值时自动标记。图书库存管理模块的作流程如图2.4.5-1所示。图书库存管理图书库存报警图书库存盘点图书库存查询退出库存管理图2.4.5-1 图书库存管理模块模块流程图2.4.6 系统管理系统管理包括供应商管理、修改管理员密码、关于本系统。结账管理的操作流程如图2.4.6-1所示。系统管理关于系统供应商管理修改密码退出系统管理图2.4.6-1 系统管理的操作流程图3数据库结构的设计与实现3.1 数据表的创建 根据系统需求,可以详细设计个数据库对象,包括数据表、视图等。表3.1-1管理员表(admin)序号名称字段类型是否允许为空1登录名adminUsernameVarchar(20)否2密码adminPasswordVarchar(20)是 表3.1-2图书退货表(buyInfo)序号名称字段类型备注1编号buyBackIdIdInt(4)否2商品编号goodNovarchar(20)是3出版公司supplierNamevarchar(50)是4价格pricefloat是5数量numberint是6总价totalPricefloat是7退回日期buyBackDatedatetime是8退回原因buyBackReasontext是9退回添加日期buyBackAddTimedatetime是10用户名UsernameVarchar(50)是11添加时间AddtimeVarchar(50)是表3.1-3图书购买信息表(buyInfo)序号名称字段类型备注1编号buyIdInt(4)主键,自增长2商品编号goodNovarchar(20)可为空3出版商supplierNamenvarchar(50)可为空4价格priceFloat可为空5数量numberInt(4)可为空6总价totalPricefloat可为空7付款日期buyDatedatetime可为空8信息添加日期addTimedatetime可为空表3.1-4学历表(educationInfo)序号名称字段类型备注1编号educationIdInt(4)主键,自增长2名称educationNamenvarchar(20)可为空表3.1-5员工表(employeeInfo)序号名称字段类型备注1编号employeeNovarchar(20)主键,自增长2员工姓名employeeNamenvarchar(20)可为空3登陆密码employeePasswordvarchar(30)可为空4性别employeeSexnchar(1)可为空5生日employeeBirthdaydatetime可为空6学历employeeEducationIdint可为空7家庭电话employeeHomeTelvarchar(20)可为空8手机employeeMobilevarchar(20)可为空9身份证employeeCardvarchar(20)可为空10电子邮件employeeEmailvarchar(30)可为空11地址employeeAddressnvarchar(80)可为空表3.1-6销售业绩表(employeeSellResult)序号名称字段类型备注1编号employeeNovarchar(20)主键,自增长2名称employeeNamenvarchar(20)可为空3销售金额employeeSellMoneyfloat可为空4系统的具体设计与实现4.1 类与方法在系统代码的编写过程中,经常会用到一些共用的代码,为减少代码的重复,使系统的可读性更强,使用性更好,可以将这些公用的代码编写成类。比如,下面将对本管理系统用到的部分类进行介绍,其代码如下所示。DBOperation.cs(数据库操作类)public static int ExecuteNonQuery(string connString, CommandType cmdType, string cmdText, params SqlParameter cmdParms) SqlCommand cmd = new SqlCommand();using (SqlConnection conn = new SqlConnection(connString) PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);int val = cmd.ExecuteNonQuery();cmd.Parameters.Clear();return val;public static int ExecuteNonQuery(SqlConnection conn, CommandType cmdType, string cmdText, params SqlParameter cmdParms) SqlCommand cmd = new SqlCommand();PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);int val = cmd.ExecuteNonQuery();cmd.Parameters.Clear();return val;public static int ExecuteNonQuery(SqlTransaction trans, CommandType cmdType, string cmdText, params SqlParameter cmdParms) SqlCommand cmd = new SqlCommand();PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, cmdParms);int val = cmd.ExecuteNonQuery();cmd.Parameters.Clear();return val;4.2 主页面设计在进入主界面之前,需要用户进行身份验证,即进行后台登录,当用户在后台登录进入主页面后,便可以进行整个系统的操作。页面显示效果如图4.2-1所示。图4.2-1 页面显示效果图这里主要用到了用户自定义控件,以解决用户界面公共部分进行重复的加载。在登陆部分系统根据DropDownList选择的值系统判断登录者身份,以进入相应的页面,该事件将会在页面加载时执行相关的操作,其代码如下所示。Button1_Click(object sender, EventArgs e) protected void Button1_Click(object sender, EventArgs e) /*取得帐号密码信息*/ string userName = this.txtName.Text; string password = this.txtPwd.Text; string identify = this.Identify.SelectedValue; if ("管理员" = identify) AdminModel adminModel = new AdminModel(); adminModel.AdminUsername = userName; adminModel.AdminPassword = password; AdminLogic adminLogic = new AdminLogic(); /*如果管理员帐号信息正确*/ if (adminLogic.IsExistAdminInfo(adminModel) Session"adminFlag" = true; Session"adminUsername" = userName; Response.Redirect("Admin/index.aspx"); /*如果管理员帐号信息不正确*/ else Response.Write("<script>alert('" + adminLogic.ErrMessage + "');</script>"); else /*如果员工帐号信息正确*/ EmployeeLogic employeeLogic = new EmployeeLogic(); if(employeeLogic.CheckLogin