药店商品管理平台 毕业设计源码56458

赠送源码-毕业设计:SSM药店商品管理平台icon-default.png?t=N7T8https://www.bilibili.com/video/BV1ic411b7JE/?vd_source=72970c26ba7734ebd1a34aa537ef5301

SSM药店商品管理平台

摘  要

科技进步的飞速发展引起人们日常生活的巨大变化,电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流,人类发展的历史正进入一个新时代。在现实运用中,应用软件的工作规则和开发步骤,采用SSM框架开发药店商品管理平台。

本设计主要实现集人性化、高效率、便捷等优点于一身的药店商品管理平台,完成首页、用户管理药品类别、药品信息、药品销售、药品退货、药品入库、入库退货、调货信息、库存盘点、销售结账等功能模块。系统通过浏览器与服务器进行通信,实现数据的交互与变更。本系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。药店商品管理平台开发是采用基于 MVC模式的SSM框架进行开发,使用 MyEclipse 2017 CI 10 编译器编写,数据方面主要采用的是微软的MySQL关系型数据库来作为数据存储媒介,配合前台HTML+CSS 技术完成系统的开发。

关键词 药店管理;数据库;SSM 

SSM Pharmacy Commodity Management Platform

Abstract

 The rapid development of science and technology has caused tremendous changes in people's daily lives. The rapid development of electronic information technology has made the application level of electronic information technology in various fields popular and applied. The arrival of the information age has become an irresistible fashion trend, and the history of human development is entering a new era. In practical application, the working rules and development steps of the application software are used to develop a pharmacy commodity management platform using the SSM framework.

This design mainly implements a pharmacy commodity management platform that integrates the advantages of humanization, efficiency, and convenience, and completes functional modules such as home page, user management, drug category, drug information, drug sales, drug returns, drug warehousing, warehousing returns, transfer information, inventory checking, and sales settlement. The system communicates with the server through a browser to achieve data interaction and change. This system improves work efficiency and reduces errors and omissions in data storage through scientific management methods and convenient services. The development of the pharmacy commodity management platform is based on the SSM framework of the MVC model, and is written using the MyEclipse 2017 CI 10 compiler. In terms of data, Microsoft's MySQL relational database is mainly used as the data storage medium, and the development of the system is completed with the front end HTML+CSS technology.

Key words:Pharmacy management; database SSM

目    录

1 概述

1.1课题目的及意义

1.2 主要工作内容

1.3 本文的组织结构

2 系统开发工具介绍

2.1 J2EE技术

2.2 MVC模式

2.3 MySQL数据库

2.4 B/S结构

2.5 SSM框架

2.6 MyEclipse开发工具

2.7 B/S体系工作原理

3 系统分析 6

3.1 可行性分析 6

3.1.1 技术可行性 6

3.1.2操作可行性 6

3.1.3 经济可行性 7

3.1.4 法律可行性 7

3.2系统流程分析 7

3.2.1系统开发流程 7

3.2.2 用户登录流程

3.2.3 系统操作流程

3.2.4 添加信息流程

3.2.5 修改信息流程

3.2.6 删除信息流程

3.3系统用例分析

3.3.1管理员用例图

3.3.2用户前台用例图

4 系统设计

4.1 系统概述

4.2 系统结构设计

4.3数据库设计 14

4.3.1 数据库设计原则

4.3.2 数据库实体

4.3.3 数据库表设计

5系统统详细设计 25

5.1用户功能模块 25

5.2管理员功能模块 28

6系统测试 33

6.1系统测试的意义

6.2 测试方法 34

6.3测试分析

     35

     36

参考文献 37

1 概述

1.1课题目的及意义

现代化科学技术的高速发展,使药店的经营管理越来越复杂。工作人员在日常工作中需要处理的信息,不但在数量上逐渐增加,而且各种数据之间的相互关联及其加工整理的要求更为复杂。因此,药店药品信息处理必须更加迅速、准确无误,否则无法满足现代化管理的需要。但在手工操作方式下,随着工作量的不断增大,药店管理人员整日忙于繁琐的事务性工作,既无时间,又不能很好地对药品信息进行处理,对药品的信息很难及时进行分析、实施监督。同时要提高市场竞争力,还要有好的客户服务。在手工管理的情况下,药品销售人员很难对客户做出正确的供货承诺。药店要做到及时响应客户的需求,就必须有准确无误的相关信息,只有这样才能在竞争中获得最佳效益。一个较好的管理系统能够提供相关信息的查询,实时、准确地反映药店药品的经营状况,使管理者做出更好的预测和决策。药店管理信息系统正是为了适应这种形势,利用现代化管理工具,使药店的管理更高效更快捷,并由人工管理向计算机管理转化。它既减少了人力、财力的消耗,也提高了管理的效率和准确度,使管理者能更加方便、快捷、有效的完成工作。

药店商品管理平台包括该药品信息、药品的销售、库存盘点等,它是药店信息化管理的重要组成部分。药店管理是一项琐碎、复杂而又十分细致的工作,手工进行药房日常的进销存等工作,容易出现“开空单”的现象,且呆账,错账时有发生。正是药店管理的这种蜇复性、规律性、时间性,使得药店管理计算机信息化成为可能。计算机进行药店的日常管理工作,不仅能够保证药品的进销存的核算正确无误,而且还可以严格规范企业的应收应付管理,并利用先进的管理模式,推动药店的快速发展,实现店管理工作的系统化、规范化和自动化。

1.2 主要工作内容

随着21世纪的来到,计算机软件得到了前所未有的发展,正在影响我们身边的每一件事。从过去学术的角度来看软件,它正在越来越走向实际,已然成为这个世界重要的元素组成之一,所以我们才会想要利用所学来解决当前药店的麻烦以及困惑,加快企业的发展。这几年以来,发展迅速的不止其它行业,计算机行业发展的十分快,并且规模没有停下来过的一直在扩大,软件渗透到各行各业的应用中,在促进信息化产业的发展中发挥了非常积极的作用。网络软件现如今成为网络上最基本运行的平台,互联网的蓬勃发展以及应运而生的电子商务给软件开发带来了巨大的商机。围绕互联网开发软件成为软件的开发新潮和热潮。软件作为信息产业的核心、国家经济和社会发展的战略性基础,软件的价值及其巨大辐射性将会得到社会各方面的足够重视,这将是未来的必然发展趋势以及未来的新潮流。

1.3本文的组织结构

第一章是绪论,本文章的开头部分,对本题目的研究背景和研究意义等一些做文字性的描述。

第二章研究了药店商品管理平台的所采用的开发技术和开发工具。

第三章是系统分析部分,包括系统总体需求描述、功能性角度分析系统需求、非功能性等各个方面分析系统是否可以实现。

第四章是系统设计部分,本文章的重要部分,提供了系统架构的详细设计和一些主要功能模块的设计说明。

第五章是系统的具体实现,介绍系统的各个模块的具体实现。

第六章在前几章的基础上对系统进行测试和运行。

最后对系统进行了认真的总结,以此对未来有一个新的展望。

2 系统开发环境  

2.1 J2EE技术

人可以掌握多门外语,而一个计算机科学家精通的大多是编程语言,它不是人类的自然语言,比如C语言、Java、Perl等等。由于不同的公司开发出的“中间件”不够规范,所以Sun公司推出J2EE,用这个标准来解决弊病。它提供了良好的机制,让每个层次允许与之相对的服务器、组件运行,使得系统的搭建稳定可用、开发高效、维护方便[1][2]。

2.2MVC模式

MVC模式是常用的开发模式,主要是在代码实现上将其分为M层、V层和C层。

视图(View)代表用户交互界面,一个 Web 应用就可能有很多的界面,在 MVC 模式中,视图仅仅处理的只有数据采集、处理,还有用户的请求, 并不包括业务流程的处理,业务流程由模型(Model)来处理[3]。

模型(Model)就是业务流程/状态的处理及业务规则的制定。模型处理业务流程的过程其它层是无法看见了的,它就像黑箱子,在接受视图请求的数据之后,然后返回最终的处理结果。MVC 最主要的核心就是业务模型的设计,一个典型的应用例子就是目前流行的 EJB 模型,它从应用技术实现的角度对模型做了进一步的划分,以便充分利用现有的组件,但是它不能作为应用设计模型的框架[4]。

控制器(Controller)可以理解为接收用户的请求,然后视图和模型匹配在一起,一起再完成用户请求。它有非常明显的作用在划分控制层上,可以很清晰地告诉你,它就是一个分发器,选择什么样的模型、视图,可以完成用户的什么样的请求。控制层不做所有的数据处理,比如说:用户点击一个连接,控制层接受到请求之后,并不处理业务信息,它只是向模型传递用户的信息,同时告诉模型做什么,然后选择符合需求的视图返回给用户[5][6]。

2.3MySQL数据库

科技的进步,给日常带来许多便利:教室的投影器用到了虚拟成像技术,数码相机用到了光电检测技术,比如超市货物进出库的记录需要一个信息仓库。这个信息仓库就是数据库,而这次的物流信息管理系统也需要这项技术的支持[7]。

用MySQL这个软件,是因为它能接受多个使用者访问,而且里面存在Archive等。它会先把数据进行分类,然后分别保存在表里,这样的特别操作就会提高数据管理系统自身的速度,让数据库能被灵活运用。MySQL的代码是公开的,而且允许别人二次编译升级。这个特点能够降低使用者的成本,再搭配合适的软件后形成一个良好的网站系统。虽然它有缺点,但是综合各方面来说,它是使用者的主流运用的对象[8]。

2.4B/S结构

B/S(Browser/Server)比前身架构更为省事的架构。它借助Web server完成数据的传递交流。只需要下载浏览器作为客户端,那么工作就达到“瘦身”效果, 不需要考虑不停装软件的问题[9]。

2.5SSM框架

SSM即SpringMVC+Spring+Mybatis,这三个框架有各自最独有的优势,那么将它们组合在一起能够碰撞出很强的火花。设计者在不需消耗大量功夫,能做出Web应用程序,而且这个程序还具有层次清晰、升级更新操作不影响正常使用的、允许多次使用的特点。这个复合框架形成一个有着结构完整、功能强大和结构良好的体系:SpringMVC使各板块分离,Spring使开发更灵活方便,使用Mybatis让开发者直接对对象进行操纵,各层次分工明细,并实现各个层次间的解耦,让代码更加的灵活精简。这个框架使程序员能够规避在开发时期避免个别错误导致整体被破坏,也能在后期应对客户对产品提出的新需求[10] [11]。

2.6MyEclipse开发工具

MyEclipse是由Genuitec公司开发的,一款功能非常强大的JavaEE的集成开发环境,其中包括有:完备的编码、调试、测试和发布功能[10],完整支持JSP、Spring、CSS、JavaScript、SpringMVC、HTML、JSF、Mybatis、SQL等技术。在体系结构上,MyEclipse的特征可以被分为7类:JavaEE模型;Web开发工具、EJB开发工具、JavaEE项目部署服务、应用程序服务器的而连接器、数据库服务、MyEclipse整合帮助[11]。

对于以上每一种功能的类别,在MyEclipse中都有相应的功能部件,并通过一系列的插件来实现它们。MyEclipse在结构上的这种模块化,可以让它在不影响其他模块的情况下,对其中任意的一个模块进行单独的扩展和升级。强大的MyEclipse应用开发平台也不仅仅只是Eclipse的插件而已,同时更是一款功能强大的,用于JavaEE的集成开发环境[12]。

2.7B/S体系工作原理:

B/S架构采取浏览器请求,服务器响应的工作模式。

用户可以通过浏览器去访问Internet上由Web服务器产生的文本、数据、图片、动画、视频点播和声音等信息;

而每一个Web服务器又可以通过各种方式与数据库服务器连接,大量的数据实际存放在数据库服务器中;

从Web服务器上下载程序到本地来执行,在下载过程中若遇到与数据库有关的指令,由Web服务器交给数据库服务器来解释执行,并返回给Web服务器,Web服务器又返回给用户。在这种结构中,将许许多多的网连接到一块,形成一个巨大的网,即全球网。而各个企业可以在此结构的基础上建立自己的Internet。

在 B/S 模式中,用户是通过浏览器针对许多分布于网络上的服务器进行请求访问的,浏览器的请求通过服务器进行处理,并将处理结果以及相应的信息返回给浏览器,其他的数据加工、请求全部都是由Web Server完成的。通过该框架结构以及植入于操作系统内部的浏览器,该结构已经成为了当今软件应用的主流结构模式。

3 系统分析

所谓系统分析就是,需求人员通过与用户的沟通,所获取的信息,然后把这些信息通过需求说明书的方式展示给用户和开发人员。在软件功能发展的历史长河中,很长时间,特别是最开始的时候,需求分析的重要性并不被人们所认同,例如当时美国IBM公司为英国电信公司开发一套信息管理系统,在需求不明确的情况下开始开发,最初的工期为一年,由于需求获取不清晰导致工期推迟了半年多,造成巨大损失。我们很多软件公司也存在这种情况,边需求,边开发,甚至与用户没有沟通清楚的情况下,直接照搬同类型的项目进行更改,导致到系统验收的时候,重新更改,造成了人力、物力的极大浪费。而导致这一切后果的原因就是需求获取不及时、不清楚、不全面。

3.1 可行性分析

药店商品管理平台主要目标是实现用户管理、药品类别、药品信息、药品销售、药品退货、药品入库、入库退货、调货信息、库存盘点、销售结账的相关信息管理服务。在确定了目标后,我们从以下四方面对能否实现本系统目标进行可行性分析。

3.1.1 技术可行性

药店商品管理平台主要采用SSM框架,基于B/S结构,Mysql数据库,对于应用程序的开发要求具备完整功能,使用简单的特点,并建立一个数据完整安全稳定的数据库。药店商品管理平台的开发技术具有很高可行性,且开发人员掌握了一定的开发技术,所以系统的开发具有可行性。

3.1.2操作可行性

药店商品管理平台的登录界面简单易于操作,采用常见的界面窗口来登录界面,通过电脑进行访问操作,会员只要平时使用过电脑都能进行访问操作。此系统的开发采用java语言开发,基于B/S结构,这些开发环境使系统更加完善。本系统具有易操作、易管理、交互性好的特点,在操作上是非常简单的。因此本系统可以进行开发。

3.1.3 经济可行性

药店商品管理平台是基于B/S模式,采用Mysql数据库储存数据,所要求的硬件和软件环境,市场上都很容易购买,程序开发主要是管理系统的开发和维护。所以程序在开发人力、财力上要求不高,而且此系统不是很复杂,开发周期短,在经济方面具有较高的可行性。

3.1.4 法律可行性

药店商品管理平台是自己设计的管理系统,具有很大的实际意义。因为无论是软件还是数据库,采用的都是开源代码,因此这个系统的开发和设计,并不存在侵权等问题,在法律上完全具有可行性。

综上所述,药店商品管理平台在技术、经济、操作和法律上都具有很高的可行性,开发此程序是可行的。

3.2系统流程分析

3.2.1系统开发流程

药店商品管理平台开发时,首先进行需求分析,进而对系统进行总体的设计规划,设计系统功能模块,数据库的选择等,本系统的开发流程如图3-1所示

药店商品管理平台 毕业设计源码56458_第1张图片

图3-1系统开发流程图

3.2.2 用户登录流程

为了保证系统的安全性,要使用本系统对系统信息进行管理,必须先登陆到系统中。如图3-2所示。

药店商品管理平台 毕业设计源码56458_第2张图片

图3-2 登录流程图

3.2.3 系统操作流程

用户打开并进入系统后,会先显示登录界面,输入正确的用户名和密码,系统自动检测信息,若信息无误,则用户会进入系统功能界面,进行操作,否则会提示错误无法登录,操作流程如图3-3所示。

药店商品管理平台 毕业设计源码56458_第3张图片

图3-3 系统操作流程图

3.2.4 添加信息流程

管理员可以对书籍类型管理进行信息的添加,用户可以对自己权限内的信息进行添加,输入信息后,系统会自行验证输入的信息和数据,若信息正确,会将其添加到数据库内,若信息有误,则会提示重新输入信息,添加信息流程如图3-4所示。

药店商品管理平台 毕业设计源码56458_第4张图片

图3-4 添加信息流程图

3.2.5 修改信息流程

管理员可以对书籍信息管理进行的修改,用户可以对自己权限内的信息进行修改,首先进入修改信息界面,输入修改信息数据,系统进行数据的判断验证,修改信息合法则修改成功,信息更新至数据库,信息不合法则修改失败,重新输入。修改信息流程图如图3-5所示。

药店商品管理平台 毕业设计源码56458_第5张图片

图3-5 修改信息流程图

3.2.6 删除信息流程

管理员可以对留言板管理进行信息的删除,对要删除的信息进行选中后,点击删除按钮,系统会询问是否确定,若点击确定,则系统会删除掉选中的信息,并在数据库内对信息进行删除,删除信息流程图如图3-6所示。

药店商品管理平台 毕业设计源码56458_第6张图片

图3-6 删除信息流程图

3.3系统用例分析

3.3.1管理员用例图

系统中的核心用户系统管理员,管理员登录后,通过管理员菜单来管理后台系统。主要功能有:用户管理、药品类别管理、药品信息管理、药品销售管理、药品退货管理、药品入库管理、入库退货管理、调货信息管理、库存盘点管理、销售结账管理等功能。管理员用例如图3-7所示。

药店商品管理平台 毕业设计源码56458_第7张图片

图3-7 管理员用例图

3.3.2会员用例图

会员进入系统拥有注册登录药品信息药品信息、药品销售、一对一问诊功能等。会员用例如图3-8所示。

药店商品管理平台 毕业设计源码56458_第8张图片

图3-8 会员用例图

3.3.3供应商用例图

供应商进入系统可以拥有有药品入库、入库退货、入库结账功能等。供应商用例如图3-9所示。

药店商品管理平台 毕业设计源码56458_第9张图片

图3-9 供应商用例图

3.3.4医师用例图

医师进入系统可以进行会员用户的一对一问诊服务回复医师用例如图3-10所示。

药店商品管理平台 毕业设计源码56458_第10张图片

图3-10 医师用例图

4 系统设计

4.1 系统概述

进过系统的分析后,就开始记性系统的设计,系统设计包含总体设计和详细设计。总体设计只是一个大体的设计,经过了总体设计,我们能够划分出系统的一些东西,例如文件、文档、数据等。而且我们通过总体设计,大致可以划分出了程序的模块,以及功能。但是只是一个初步的分类,并没有真正的实现。

整体设计,只是一个初步设计,而且,对于一个项目,我们可以进行多个整体设计,通过对比,包括性能的对比、成本的对比、效益的对比,来最终确定一个最优的设计方案,选择优秀的整体设计可以降低开发成本,增加公司效益,从这一点来讲,整体设计还是非常重要的。

药店商品管理平台工作原理图如图4-1所示:

药店商品管理平台 毕业设计源码56458_第11张图片

图4-1 系统工作原理图

4.2 系统结构设计

系统架构图属于系统设计阶段,系统架构图只是这个阶段一个产物,系统的总体架构决定了整个系统的模式,是系统的基础。药店商品管理平台的整体结构设计如图4-2所示。

药店商品管理平台 毕业设计源码56458_第12张图片

图4-2 系统结构图

4.3数据库设计

数据库是计算机信息系统的基础。目前,电脑系统的关键与核心部分就是数据库。数据库开发的优劣对整个系统的质量和速度有着直接影响。

4.3.1 数据库设计原则

数据库的概念结构设计采用实体—联系(E-R)模型设计方法。E-R模型法的组成元素有:实体、属性、联系,E-R模型用E-R图表示,是提示用户工作环境中所涉及的事物,属性则是对实体特性的描述。在系统设计当中数据库起着决定性的因素。下面设计出这几个关键实体的实体—关系图

4.3.2 数据库实体

数据模型中的实体(Entity),也称为实例,对应现实世界中可区别于其他对象的“事件”或“事物”。

本系统的E-R图如下图所示:

1、药品信息实体图如图4-3所示:

药店商品管理平台 毕业设计源码56458_第13张图片

图4-3药品信息实体图

2、会员信息实体图如图4-4所示:

药店商品管理平台 毕业设计源码56458_第14张图片

图4-4会员信息实体图

3一对一问诊实体图如图4-5所示:

药店商品管理平台 毕业设计源码56458_第15张图片

图4-5一对一问诊实体图

4.3.3 数据库表设计

表access_token (登陆访问时长)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

token_id

int

10

0

N

Y

临时访问牌ID

2

token

varchar

64

0

Y

N

临时访问牌

3

info

text

65535

0

Y

N

4

maxage

int

10

0

N

N

2

最大寿命:默认2小时

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

7

user_id

int

10

0

N

N

0

用户编号:

表article (文章:用于内容管理系统的文章)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

article_id

mediumint

8

0

N

Y

文章id:[0,8388607]

2

title

varchar

125

0

N

Y

标题:[0,125]用于文章和html的title标签中

3

type

varchar

64

0

N

N

0

文章分类:[0,1000]用来搜索指定类型的文章

4

hits

int

10

0

N

N

0

点击数:[0,1000000000]访问这篇文章的人次

5

praise_len

int

10

0

N

N

0

点赞数

6

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

7

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

8

source

varchar

255

0

Y

N

来源:[0,255]文章的出处

9

url

varchar

255

0

Y

N

来源地址:[0,255]用于跳转到发布该文章的网站

10

tag

varchar

255

0

Y

N

标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开

11

content

longtext

2147483647

0

Y

N

正文:文章的主体内容

12

img

varchar

255

0

Y

N

封面图

13

description

text

65535

0

Y

N

文章描述

表article_type (文章分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]决定分类显示的先后顺序

3

name

varchar

16

0

N

N

分类名称:[2,16]

4

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

5

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

6

icon

text

65535

0

Y

N

分类图标:

7

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表auth (用户权限管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

auth_id

int

10

0

N

Y

授权ID:

2

user_group

varchar

64

0

Y

N

用户组:

3

mod_name

varchar

64

0

Y

N

模块名:

4

table_name

varchar

64

0

Y

N

表名:

5

page_title

varchar

255

0

Y

N

页面标题:

6

path

varchar

255

0

Y

N

路由路径:

7

position

varchar

32

0

Y

N

位置:

8

mode

varchar

32

0

N

N

_blank

跳转方式:

9

add

tinyint

3

0

N

N

1

是否可增加:

10

del

tinyint

3

0

N

N

1

是否可删除:

11

set

tinyint

3

0

N

N

1

是否可修改:

12

get

tinyint

3

0

N

N

1

是否可查看:

13

field_add

text

65535

0

Y

N

添加字段:

14

field_set

text

65535

0

Y

N

修改字段:

15

field_get

text

65535

0

Y

N

查询字段:

16

table_nav_name

varchar

500

0

Y

N

跨表导航名称:

17

table_nav

varchar

500

0

Y

N

跨表导航:

18

option

text

65535

0

Y

N

配置:

19

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表collect (收藏)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

collect_id

int

10

0

N

Y

收藏ID:

2

user_id

int

10

0

N

N

0

收藏人ID:

3

source_table

varchar

255

0

Y

N

来源表:

4

source_field

varchar

255

0

Y

N

来源字段:

5

source_id

int

10

0

N

N

0

来源ID:

6

title

varchar

255

0

Y

N

标题:

7

img

varchar

255

0

Y

N

封面:

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表comment (评论)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

comment_id

int

10

0

N

Y

评论ID:

2

user_id

int

10

0

N

N

0

评论人ID:

3

reply_to_id

int

10

0

N

N

0

回复评论ID:空为0

4

content

longtext

2147483647

0

Y

N

内容:

5

nickname

varchar

255

0

Y

N

昵称:

6

avatar

varchar

255

0

Y

N

头像地址:[0,255]

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

9

source_table

varchar

255

0

Y

N

来源表:

10

source_field

varchar

255

0

Y

N

来源字段:

11

source_id

int

10

0

N

N

0

来源ID:

表drugs_warehousing (药品入库)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drugs_warehousing_id

int

10

0

N

Y

药品入库ID

2

receipt_no

varchar

64

0

Y

N

入库单号

3

drug_no

varchar

64

0

Y

N

药品编号

4

drug_name

varchar

64

0

Y

N

药品名称

5

drug_category

varchar

64

0

Y

N

药品类别

6

drug_specification

varchar

64

0

Y

N

药品规格

7

supplier

int

10

0

Y

N

0

供应商

8

receipt_quantity

int

10

0

Y

N

0

入库数量

9

receipt_price

varchar

64

0

Y

N

入库价格

10

receipt_amount

varchar

64

0

Y

N

入库金额

11

warehousing_time

date

10

0

Y

N

入库时间

12

warehousing_instructions

text

65535

0

Y

N

入库说明

13

recommend

int

10

0

N

N

0

智能推荐

14

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表drug_category (药品类别)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drug_category_id

int

10

0

N

Y

药品类别ID

2

drug_category

varchar

64

0

Y

N

药品类别

3

recommend

int

10

0

N

N

0

智能推荐

4

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

5

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表drug_information (药品信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drug_information_id

int

10

0

N

Y

药品信息ID

2

drug_no

varchar

64

0

Y

N

药品编号

3

drug_name

varchar

64

0

Y

N

药品名称

4

drug_category

varchar

64

0

Y

N

药品类别

5

drug_specification

varchar

64

0

Y

N

药品规格

6

picture

varchar

255

0

Y

N

图片

7

stock

int

10

0

Y

N

0

库存

8

original_price

varchar

64

0

Y

N

原价

9

membership_price

varchar

64

0

Y

N

会员价

10

drug_properties

varchar

64

0

Y

N

药品性状

11

drug_efficacy

text

65535

0

Y

N

药品功效

12

drug_use

text

65535

0

Y

N

药品用途

13

drug_usage

text

65535

0

Y

N

药品用法

14

drug_introduction

longtext

2147483647

0

Y

N

药品介绍

15

hits

int

10

0

N

N

0

点击数

16

praise_len

int

10

0

N

N

0

点赞数

17

recommend

int

10

0

N

N

0

智能推荐

18

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

19

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表drug_sales (药品销售)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drug_sales_id

int

10

0

N

Y

药品销售ID

2

sales_order_no

varchar

64

0

Y

N

销售单号

3

drug_no

varchar

64

0

Y

N

药品编号

4

drug_name

varchar

64

0

Y

N

药品名称

5

drug_category

varchar

64

0

Y

N

药品类别

6

drug_specification

varchar

64

0

Y

N

药品规格

7

membership_price

varchar

64

0

Y

N

会员价

8

member_number

int

10

0

Y

N

0

会员编号

9

member_name

varchar

64

0

Y

N

会员姓名

10

purchase_quantity

int

10

0

Y

N

0

购买数量

11

total_price

varchar

64

0

Y

N

总价

12

remarks

text

65535

0

Y

N

备注

13

recommend

int

10

0

N

N

0

智能推荐

14

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表hits (用户点击)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

hits_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

表inventory_count (库存盘点)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

inventory_count_id

int

10

0

N

Y

库存盘点ID

2

drug_no

varchar

64

0

Y

N

药品编号

3

drug_name

varchar

64

0

Y

N

药品名称

4

drug_category

varchar

64

0

Y

N

药品类别

5

drug_specification

varchar

64

0

Y

N

药品规格

6

stock

varchar

64

0

Y

N

库存

7

count

varchar

64

0

Y

N

盘点数

8

storage_warehouse

varchar

64

0

Y

N

储存仓库

9

checked_by

varchar

64

0

Y

N

盘点人

10

counting_date

date

10

0

Y

N

盘点日期

11

counting_description

text

65535

0

Y

N

盘点说明

12

recommend

int

10

0

N

N

0

智能推荐

13

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

14

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表member_users (会员用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

member_users_id

int

10

0

N

Y

会员用户ID

2

member_number

varchar

64

0

N

N

会员编号

3

member_name

varchar

64

0

Y

N

会员姓名

4

gender

varchar

64

0

Y

N

性别

5

examine_state

varchar

16

0

N

N

已通过

审核状态

6

recommend

int

10

0

N

N

0

智能推荐

7

user_id

int

10

0

N

N

0

用户ID

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表notice (公告)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

notice_id

mediumint

8

0

N

Y

公告id:

2

title

varchar

125

0

N

N

标题:

3

content

longtext

2147483647

0

Y

N

正文:

4

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

5

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表one_to_one_consultation (一对一问诊)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

one_to_one_consultation_id

int

10

0

N

Y

一对一问诊ID

2

member_number

int

10

0

Y

N

0

会员编号

3

member_name

varchar

64

0

Y

N

会员姓名

4

consultation_content

text

65535

0

Y

N

问诊内容

5

doctor_no

int

10

0

Y

N

0

医师工号

6

doctors_reply

text

65535

0

Y

N

医师回复

7

examine_state

varchar

16

0

N

N

未审核

审核状态

8

recommend

int

10

0

N

N

0

智能推荐

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表physician_user (医师用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

physician_user_id

int

10

0

N

Y

医师用户ID

2

doctor_id

varchar

64

0

N

N

医师工号

3

physicians_name

varchar

64

0

Y

N

医师姓名

4

examine_state

varchar

16

0

N

N

已通过

审核状态

5

recommend

int

10

0

N

N

0

智能推荐

6

user_id

int

10

0

N

N

0

用户ID

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

5统详细设计

5.1用户功能模块

药店商品管理平台,在系统首页可以查看首页、药品新闻药品信息药品销售等内容,如图5-1所示。

药店商品管理平台 毕业设计源码56458_第16张图片

图5-1用户前台功能界面图

   

    用户注册,在用户注册页面可以填写账号、密码、昵称邮箱手机号码身份、性别、身份证号码等详细内容进行注册,如图5-2所示。

药店商品管理平台 毕业设计源码56458_第17张图片

图5-2用户注册界面图

用户注册关键代码如下所示。

/**

  * 登录

     * @param data

     * @param httpServletRequest

     * @return

     */

    @PostMapping("login")

    public Map login(@RequestBody Map data, HttpServletRequest httpServletRequest) {

        log.info("[执行登录接口]");

        String username = data.get("username");

        String email = data.get("email");

        String phone = data.get("phone");

        String password = data.get("password");

        List resultList = null;

        Map map = new HashMap<>();

        if(username != null && "".equals(username) == false){

            map.put("username", username);

            resultList = service.select(map, new HashMap<>()).getResultList();

        }

        else if(email != null && "".equals(email) == false){

            map.put("email", email);

            resultList = service.select(map, new HashMap<>()).getResultList();

        }

        else if(phone != null && "".equals(phone) == false){

            map.put("phone", phone);

            resultList = service.select(map, new HashMap<>()).getResultList();

        }else{

            return error(30000, "账号或密码不能为空");

        }

        if (resultList == null || password == null) {

            return error(30000, "账号或密码不能为空");

        }

        //判断是否有这个用户

        if (resultList.size()<=0){

            return error(30000,"用户不存在");

        }

        User byUsername = (User) resultList.get(0);

        Map groupMap = new HashMap<>();

        groupMap.put("name",byUsername.getUserGroup());

        List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();

        if (groupList.size()<1){

            return error(30000,"用户组不存在");

        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态

        if (!StringUtils.isEmpty(userGroup.getSourceTable())){

            String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();

            String res = String.valueOf(service.runCountSql(sql).getSingleResult());

            if (res==null){

                return error(30000,"用户不存在");

            }

            if (!res.equals("已通过")){

                return error(30000,"该用户审核未通过");

            }

        }

        //查询用户状态

        if (byUsername.getState()!=1){

            return error(30000,"用户非可用状态,不能登录");

        }

        String md5password = service.encryption(password);

        if (byUsername.getPassword().equals(md5password)) {

            // 存储Token到数据库

            AccessToken accessToken = new AccessToken();

            accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

            accessToken.setUser_id(byUsername.getUserId());

            tokenService.save(accessToken);

            // 返回用户信息

            JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

            user.put("token", accessToken.getToken());

            JSONObject ret = new JSONObject();

            ret.put("obj",user);

            return success(ret);

        } else {

            return error(30000, "账号或密码不正确");

        }

}

登录,在登录页面通过填写账号、密码等信息完成登录,如图5-3所示。药品新闻页面可以浏览药品新闻热门列表信息等内容,如图5-4所示。

药店商品管理平台 毕业设计源码56458_第18张图片

图5-3登录界面图

用户登录的关键代码如下。

 /**

     * 登录

     * @param data

     * @param httpServletRequest

     * @return

     */

    @PostMapping("login")

    public Map login(@RequestBody Map data, HttpServletRequest httpServletRequest) {

        log.info("[执行登录接口]");

        String username = data.get("username");

        String email = data.get("email");

        String phone = data.get("phone");

        String password = data.get("password");

        List resultList = null;

        QueryWrapper wrapper = new QueryWrapper();

        Map map = new HashMap<>();

        if(username != null && "".equals(username) == false){

            map.put("username", username);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(email != null && "".equals(email) == false){

            map.put("email", email);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(phone != null && "".equals(phone) == false){

            map.put("phone", phone);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }else{

            return error(30000, "账号或密码不能为空");

        }

        if (resultList == null || password == null) {

            return error(30000, "账号或密码不能为空");

        }

        //判断是否有这个用户

        if (resultList.size()<=0){

            return error(30000,"用户不存在");

        }

        User byUsername = (User) resultList.get(0);

        Map groupMap = new HashMap<>();

        groupMap.put("name",byUsername.getUserGroup());

        List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));

        if (groupList.size()<1){

            return error(30000,"用户组不存在");

        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态

        if (!StringUtils.isEmpty(userGroup.getSourceTable())){

            String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());

            if (res==null){

                return error(30000,"用户不存在");

            }

            if (!res.equals("已通过")){

                return error(30000,"该用户审核未通过");

            }

        }

        //查询用户状态

        if (byUsername.getState()!=1){

            return error(30000,"用户非可用状态,不能登录");

        }

        String md5password = service.encryption(password);

        if (byUsername.getPassword().equals(md5password)) {

            // 存储Token到数据库

            AccessToken accessToken = new AccessToken();

            accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

            accessToken.setUser_id(byUsername.getUserId());

            tokenService.save(accessToken);

            // 返回用户信息

            JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

            user.put("token", accessToken.getToken());

            JSONObject ret = new JSONObject();

            ret.put("obj",user);

            return success(ret);

        } else {

            return error(30000, "账号或密码不正确");

        }

}

    public String select(Map query,Map config){

        StringBuffer sql = new StringBuffer("select ");

        sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");

        sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));

        if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){

            sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");

        }

        if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){

            sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");

        }

        if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){

            int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;

            int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;

            sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);

        }

        log.info("[{}] - 查询操作,sql: {}",table,sql);

        return sql.toString();

}

    public List selectBaseList(String select) {

        List> mapList = baseMapper.selectBaseList(select);

        List list = new ArrayList<>();

        for (Map map:mapList) {

            list.add(JSON.parseObject(JSON.toJSONString(map),eClass));

        }

        return list;

}

药店商品管理平台 毕业设计源码56458_第19张图片

图5-4药品新闻界面图

药品信息展示,在药品信息列表页面可以查看药品信息等,如图5-5所示。一对一问诊页面可以进行问诊问题提交,提交至对应的医师,如图5-6所示。

药店商品管理平台 毕业设计源码56458_第20张图片

图5-5药品信息界面图

药店商品管理平台 毕业设计源码56458_第21张图片

图5-6一对一问诊界面图

一对一问诊的逻辑代码如下:

@PostMapping("/add")

    @Transactional

    public Map add(HttpServletRequest request) throws IOException {

        service.insert(service.readBody(request.getReader()));

        return success(1);

    }

    @Transactional

    public Map addMap(Map map){

        service.insert(map);

        return success(1);

}

5.2管理员功能模块

管理员登录,通过填写注册时输入的用户名、密码进行登录,如图5-7所示。

药店商品管理平台 毕业设计源码56458_第22张图片

图5-7管理员登录界面图

管理员登录进入药店商品管理平台后的主要功能是:用户管理、药品类别、药品信息、药品销售、药品退货、药品入库、入库退货、调货信息、库存盘点、销售结账管理等。如图5-8所示。新闻管理主要是对新闻进行编辑发布。入图5-9所示。

药店商品管理平台 毕业设计源码56458_第23张图片

图5-8管理员功能界面图

药店商品管理平台 毕业设计源码56458_第24张图片

图5-9新闻管理界面图

新闻管理界面逻辑代码如下:

@RequestMapping("/get_obj")

    public Map obj(HttpServletRequest request) {

        List resultList = service.selectBaseList(service.select(service.readQuery(request), service.readConfig(request)));

        if (resultList.size() > 0) {

            JSONObject jsonObject = new JSONObject();

            jsonObject.put("obj",resultList.get(0));

            return success(jsonObject);

        } else {

            return success(null);

        }

}

药品销售管理,在药品销售管理页面中可以对每一类的药品销售信息进行统计维护管理,如图5-10所示。

药店商品管理平台 毕业设计源码56458_第25张图片

图5-10药品销售管理界面图

药品入库管理,在页面中可以对供应商录入的药品入库信息以及入库单号进行维护管理,如图5-11所示。

药店商品管理平台 毕业设计源码56458_第26张图片

图5-11药品入库管理界面图

药品入库管理界面逻辑代码如下:

@PostMapping("/add")

    @Transactional

    public Map add(HttpServletRequest request) throws IOException {

        Map paramMap = service.readBody(request.getReader());

        this.addMap(paramMap);

        return success(1);

}

    @Transactional

    public Map addMap(Map map){

        service.insert(map);

        return success(1);

}

入库结账管理,在入库结账页面中对药品的入库结账等信息进行维护管理,如图5-12所示。

药店商品管理平台 毕业设计源码56458_第27张图片

图5-12入库结账管理界面图

轮播图;该页面为轮播图管理界面。管理员可以在此页面进行首页轮播图的管理,通过新建操作可在轮播图中加入新的图片,还可以对以上传的图片进行修改操作,以及图片的删除操作,如图5-13所示。

药店商品管理平台 毕业设计源码56458_第28张图片

图5-13轮播图界面图

库存盘点管理,在库存盘点页面中可以对药品的库存信息进行管理,如图5-14所示。

药店商品管理平台 毕业设计源码56458_第29张图片

图5-14库存盘点管理界面图

库存盘点管理界面关键代码如下:

@RequestMapping("/get_list")

    public Map getList(HttpServletRequest request) {

        Map map = service.selectToPage(service.readQuery(request), service.readConfig(request));

        return success(map);

}

6系统测试

系统开发的最后一个步骤就是系统测试,系统测试也是整个系统十分重要的一个环节,测试的好坏关系到产品的发展。用户对软件的质量、性能和可靠性等需求就要通过测试来实现。测试过程要必须遵循严谨性、完善性、规范性的原则,测试的主要目的就是看看在系统运行中,是否会出现bug,然后对出现的bug进行调试,直到程序完美运行。但是软件的测试只能尽可能的减少bug,理论上来说是无法达到消除bug。但是bug越少,系统出错的几率就越低,用户使用起来也更方便、更安全。

近年来,软件包含测试从现在的检验当中来看,系统接近预期目标可能出现的问题,并对这些错误做出相应的修正,假如我们不进行早期的测试错误就会延续下去,最后所做出的成品就会有很大的困难。

我们要在这个测试的过程当中找出错误。测试成软件开发的主要一部分,自从有了程序的设计那天开始,它就成为了重要的组成部分。经过统计来看,软件测试可以占据这个系统45%的工作量,而在软件开发的成本当中,对于测试成本来说它包含了很多的测试工作。每个程序测试时都会出现和遇到错误。在整个程序的开发过程当中,人为去查找错误是非常复杂和困难的,所以我们一般都会找一些测试的工具来进行测试

6.1系统测试的意义

随着现代信息的快速发展,在社会各大领域中已经都开始应用网络信息技术,在应用网络技术的同时人们也开始把软件的质量问题作为了一个重要焦点来关注,因为一个软件的好与坏它决定着这个系统在市场上的生存,所以我们必须要把软件质量来做好,这样才有一定的生存能力。对于用户来说它们首先选用的都是保证这个系统软件的质量问题,因为一个系统的软件质量决定着用户在后期上成本经济的问题。

6.2 测试方法

具体测试方法包括:黑盒测试和白盒测试。

黑盒测试又被人们称作为功能测试,通常是在程序的接口来做一些测试的方法,它一般包括对程序的功能和使用的方法来做出一些数据的接受和输出,同时还可以做出正确的输出信息,并保证与外部信息的完整性。

白盒测试通常被人们称作为结构测试,在整个程序的结构和处理当中它是由程序当中的逻辑测试和检验程序来完成一些正确的工作。

具体的功能测试它是包括:系统的适用性、准确性、安全性等功能测试。

6.3测试分析

药店商品管理平台满足相关信息的管理需求,在设计时借鉴了国内外优秀网站的优点,从界面到系统设计都保证了管理员以及用户能够方便操作。系统的主要特点和优点归纳如下:

(1)本系统用的移置性和针对性都比较高,因为针对性高可以提供更好的服务而移置性可以在多个系统上运行,更给用户带来了极大的方便。

(2)该药店商品管理平台内容全面,管理方便可以及时的全面的处理各种错误,异常,这样避免了很多因用户的马虎操作而出现的失误,其操作方便,用户界面友好,能够上网的人都可以很好的进行操作。

经过对上述的测试结果分析,所有基本功能齐全,操作简单,系统运行性能良好,系统安全可靠,能促进药店商品管理平台的发展,发展前景广阔。

结    论

本系统通过对java和Mysql数据库的简介,从硬件和软件两反面说明了药店商品管理平台的可行性,本文结论及研究成果如下:实现了java与Mysql相结合构建的药店商品管理平台,网站可以响应式展示。通过本次药店商品管理平台的研究与实现,我感到学海无涯,学习是没有终点的,而且实践出真知,只有多动手才能尽快掌握它,经验对系统的开发非常重要,经验不足,就难免会有许多考虑不周之处。比如要有美观的界面,更完善的功能,才能吸引更多的用户

由于在此之前对于java知识没有深入了解,所以从一开始就碰到许多困难,例如一开始的页面显示不规范、数据库连接有问题已经无法实现参数的传递等等,不过通过在网上寻找有关资料以及同学的帮助下最后都得到了解决,在此过程中,我不仅学到了很多知识,也提高了自己解决问题的能力,尤其是学会如何从大量的信息中筛选出所需有用的信息,同时我更加深刻的体会到了,虽然书本上的大部分知识都是有价值,正确的,但实际上每个人编程的思路和对数据处理的方法、思想都是不同的,这就要求我们一定要通过实践才能找到解决问题的方案。在此次毕业设计活动中,我不断的提高了自己,也得到了宝贵的经验,我相信这些对我以后的发展都会有很大帮助。

通过这次药店商品管理平台的开发,我参考了很多相关系统的例子,取长补短,吸取了其他系统的长处,逐步对该系统进行了完善,但是该系统还是有很多的不足之处,有待以后进一步学习。

实践证明,药店商品管理平台有着非常好的发展前景,经过测试运行,系统各项功能都十分完善,界面漂亮,使用方便,操作容易,在技术理论上已经成熟。

致    谢

大学的学习生活在这个季节将结束,但是在我的生命这仅仅只是一个逗号,我将面对的旅程的另一个的开始。通过这次毕业设计的整个开发过程,从需求分析到具体功能实现,再到最终测试和维护的理解有了很大的进步,让我对系统开发有了更深刻的认识,对我个人的实践能力和解决问题的能力,都有了很大的帮助。这是这次毕业设计最大的收获。

首先要感谢我的指导老师,他在论文写作上,给予了我各种无私的帮助,治学严谨,严格要求,使我获得了很大的收获。老师深厚的理论知识和丰富的实践经验,都深深的影响到我,在这方面,我谨表示衷心的感谢。

其次,我还要对所有的老师和同学表示感谢,他们在我学习的过程中,都积极的提供了很多帮助,无论是专业知识,还是实践操作技能,也能够让我在论文写作中,遇到的一些难题迎刃而解。

最后,对阅读和评审本论文的各位老师表示衷心的感谢!

参考文献 

[1]蓝惠娟.零售连锁药店财务管理[J].全国流通经济,2021(27):20-22.

[2]钟桂鸿,张茜,吴其聪,余清雅,刘佐仁.基于主题框架分析法的广东省零售药店分级分类管理政策实施现状分析[J].中国药房,2021,32(12):1421-1427.

[3]刘帆. 基于智能药品柜的零售药店监管系统设计与实现[D].山东大学,2021.

[4]颜杰群.以HTML5和ASP.NET开发中小型药店线上管理系统[J].常州信息职业技术学院学报,2021,20(01):29-32+41.

[5]杨雅麟,王智超,张宇晴,沈素,闫素英,孟丽华,叶真,甄健存.基本医疗保险定点零售药店管理情况调研[J].中国药师,2020,23(04):716-719.

[6]颜杰群.基于互联网+的中小型药店商品管理平台的设计与实现[J].上饶师范学院学报,2019,39(03):21-25+81.

[7]刘红磊.VR技术在药品管理类实训课程中的应用[J].知识经济,2019(18):133+136.

[8]张守钗,施航,何林飞.社会药店药品经营质量管理规范认证检查中存在的问题分析及对策[J].安徽医药,2018,22(12):2463-2467.

[9]周波.药店销售管理系统的分析与设计[J].电脑知识与技术,2018,13(28):60-61+109.

[10]郭凯. 连锁药店品类管理研究[D].武汉工程大学,2018.

[11]吴锦.我国零售药店分级管理实施状况、困境及对策研究[J].中国药房,2018,28(01):141-144.

[12]王雪丽. 基于云计算服务平台的单体药店商品管理平台[D].浙江工业大学,2018.

[15]Nicholas M Kelly,John Moorehead,Tony Tham.Is the ‘driving test’ a robust quality indicator of colonoscopy performance?[J].World Journal of Gastrointestinal Endoscopy,2018,2(04):112-120.

点赞+收藏+关注 → 私信领取本源代码、数据库

你可能感兴趣的:(vue.js,spring,boot,java,mysql,python)