最新药店信息管理系统软件工程.docx
《最新药店信息管理系统软件工程.docx》由会员分享,可在线阅读,更多相关《最新药店信息管理系统软件工程.docx(9页珍藏版)》请在冰豆网上搜索。
![最新药店信息管理系统软件工程.docx](https://file1.bdocx.com/fileroot1/2023-1/5/8c48c8c9-1b87-4fce-a830-60d5375e875c/8c48c8c9-1b87-4fce-a830-60d5375e875c1.gif)
最新药店信息管理系统软件工程
(最新)药店信息管理系统软件工程
1.系统概述
从本质来说,药店的职能就是为消费者提供服务,所销售的药品只是其提供的服务所附实体而已。
对于药店来说,只有服务才能形成其差异化竞争特色。
因此,分析消费者的服务需求对了解药店消费者的需求具有重要意义。
药店消费者的需求主要表现在以下几个方面:
(1)管理者能查询药店的药品库存状态,以便进行及时的药品补进和更新;
(2)消费者能通过系统快速查询药品的状态(包括是否在柜、出售价格、数量等);(3)能让消费者及时获得用药指导、合理的咨询;
(4)能让消费者感觉到服务的简捷和实用。
2.系统分析
经过系统的需求分析,初步得到了医药管理的主要步骤:
定制药品采购计划、经审核后实施药品采购、采购的药品由库管登记入库、销售员根据客户的需要登记销售药品、提交药品给客户。
经过对药店管理进行分析,药店管理信息系统要实现的主要功能有:
(1)对药品的基础信息进行维护和管理。
能够完成药品信息的添加、修改和删除,并按照一定的条件查询药品信息;
(2)对药品的批量销售处理,顾客购买的药品可能是一种也可能是多种,如果能够批量销售药品,便会大大提高工作效率;
(3)库存药品查看,可按不同字段和条件查询库存药品信息;(4)查询统计功能,要求既可以按日期查询,也可以按用户选择的字段和输入的内容查询,并在查询过程中统计销售数量和销售金额;
(5)统计分析某个客户或所有客户某段时间内药品销售品种、销售数量和销售金额。
我们把药店进—销—存管理系统划分为4大功能模块,分别为日常业务、库存管理、查询统计、基础信息管理。
其中日常业务完成药品销售、销售退货和药品入库;库存管理主要完成库存药品查询、库存药品盘点;查询统计主要完成销售查询统计和入库查询统计;基础信息管理主要完成药品信息、客户信息、供货商信息的添加、修改、删除、查询等。
另外,药店管理信息系统功能模块如下:
药店管理信息系统
日常业务库存管理查询统计基础信息管理
供药销药库库销入药客应品售品存存售库品户商销退入药盘查查信管管售货库品点询询息理理
图1药店管理信息系统功能模块2.1模型设计实体的属性表
在药店管理信息系统中我们设计了多个数据表,具体有:
药店信息表(tb,shop):
(药店号SId、药店名SName、所在地SAdd、经理SMgr、联系方式SPhn)
药品信息表(tb,medicine):
(药品编号MId、药品名称MName、规格MSize、单位MUnt、产地MAdd、有效期MData、批号MNub.、商标号MTm、出厂价MFp、零售价MRp、批发价MMp、类别MS、供货商名称MDsg)
供货商信息表(tb,provider):
(商家号PId、商家名PName、所在地PAdd、经理PSgr、联系方式PPhn、供货量PNmb)
顾客信息表(tb,client):
(顾客编号CId、顾客名称CName、地址CAdd、邮政编码CCd、联系方式CPhn、账款CCrd)
客户账款明细表(tb,client,arrearage):
(日期AData、时间ATime、摘要ASmm、数量AQun、单位AUnt、单价AUntp、金额小计ASbt、客户编号AId、客户名称AName)
销售信息表(tb,sell,detailed):
(药品编号DId、药品名称DName、规格DSize、产地DAdd、批号DNub、数量DSmm、零售价DRp、金额DMny、顾客编号DCid、顾客名称DCname、销售日期DDdata、销售单据号DDid)
库存信息表(tb,stock_information):
(药品编号IId、药品名称IName、规格ISize、产地IAdd、批号INub、有效期IData、库存数量ISnub、出厂价IFp、批发价IMp、零售价IRp)
另外,药店管理信息系统E-R图,见图2。
商家名所在地经理商家号联系方式供货量
供货商
M
提供NP
药店药品
M
1M
时间数量单价库存购买
管理
交易金额种类111M顾客
经理M药品库
查询
1顾客信息查询欠款查询
1
查询
药品库存量查询新入库药品查询
图2E-R图
2.2概念模型
通过对用户需求分析进行综合、归纳与抽象、形成一个独立于具体DBMS的
概念模型。
在本药店管理系统中涉及到了2种概念模型的抽象,如图3、图4所示:
药品
Ispartof
药品编号药品名药品规格供应商生产日期
图3聚集模型
查询
销售查询入库查询
图4概况模型
2.3用例图和顶层数据流图
《communicate》
供货商
打印购药信息《communicate》管理药店《extend》
《communicate》《communicate》
交易药品顾客
经理《communicate》《include》
查询顾客信息查询
《include》
药品库存查询
图5总体分析的用例图
药店信息库
进货查询
经理供货商
代售
图6经理与供货商的用例图
药品查询
顾客经理
顾客查询
交易更新顾客信息图7顾客与经理间的用例图
填写好的供应商信供应商信息息供应商信息供应商填写
处理好的采购单
交
易仓库信息填好的仓3.0金库信息采购额仓库填写仓库仓库信息信息所需药品药品编好号的采购单来药品信息填好的药付款自品信息依填写药品药品药品信息采购单信息据信息
信所需药品息确顾客信息下依据消费所购药品认领取发单上的药收品列表为填凭盖好章顾客确认的消货写的消费单费单2.0处理顾客经理消费单
确定未付款经理信息的消费单
未处理的消费单付款后进填写经理已编过号行的消费单信息
1.0填好的经付款理信息
消费单信息
经理信息
图8顶层数据流图
2.4用户子模式设计
将概念模型转换为全局逻辑模型后,还应该根据局部应用需求,结合具体DBMS的特点,设计用户的外模式。
在此,要设计药房药库管理子系统:
通过对药品的出入库管理,产生药品帐务的变更,提出采购计划。
能对各种药品的帐务、库存、财务台帐等项目进行查询、统计、汇总、打印,达到控制成本,提高效率的目的。
其主要功能有:
库房管理:
采购计划、入库制单、出库制单、药品调价、库存管理、药房申领。
帐务明细:
库房总帐、库房台帐、库房明细、药品盈亏、部门往来。
查询报表:
供应商查询、入库批次查询、进销存报表、入出库汇总、工作量汇总、药品营销分析。
2.5总体实施计划
不用的系统用户拥有不同的权限,这样才能保证数据库的安全性。
在本药店管理信息系统的数据库设计中,主要用户包括店主和顾客。
店主应该具有超级用户的权限,而顾客只能对数据进行简单的查询,不能修改数据库中的数据。
因此,在数据库总角色的创建,只涉及到:
?
店主权限:
增,删,改,查;?
顾客权限:
查。
在数据库初步系统设计好之后,为了检测其基本功能是否能正常实现。
先进行尝试性的运行:
检测简单的、普通的、常涉及到的操作是否能够正常的运行。
比如:
检测药店经理是否能查询顾客库中的顾客信息、顾客能否获知药店药品库的药品信息如药品生产日期、单价、功效等。
数据的载入并不是一次性的,需要药店经理不断地更新药店信息,而信息的更新建立在基本操作(进—销)之上的,这样就能有效地把药店的基本功能联系起来,同时也实现了顾客、药店、供货商之间的关系。
通过此信息管理系统,能很好地实现药店的日常管理。
在数据库刚刚设计完成后,只有将原有系统或者手工处理的数据进行转换使之符合新系统的数据模式,从而完成数据输入工作。
3.系统总体设计
(1)分解的数据流图
确认的消
费单2.3盖章顾客
打印过的
消费单
编过号的
消费单2.1分配2.2打印消费单编消费单号
付款后进分配好的行
消费单编
号
消费单信息
图9处理消费
处理好的
采购单供应商
3.2采购
单处理已编好号
的采购单
对采购单
进行编号
采购单信息3.1下采
购单
依据需求
员工
图10处理采购
(2)类图
药店交易
经理-药店号-药名
-药店名-时间-姓名
-地址-数量-联系方式10..111-经理-单位
1
1..*
0..*
查询
1
药库
-药品编号
-药品名称库存信息顾客信息-价格
-药品编号-库存数量-顾客编号
-价格-顾客姓名
-库存数量-联系方式
4.系统详细设计
需要建立索引的属性:
表1tb_shop字段类型大小是否为主键是否允许为空
SIdvarchar10是SNamevarchar30否SAddvarchar50SMgrvarchar10SPhnvarchar11
表2tb_client字段类型大小是否为主键是否允许为空
Cidvarchar10是Cnamevarchar20CAddvarchar50CPhnvarchar11CCrdvarchar10
表3tb_medicine字段类型大小是否为主键是否允许为空MIdvarchar10是MNamevarchar20否MSizevarchar10MUntvarchar10MAddvarchar50否
MDatavarchar10MNubvarchar20MTmvarchar20MFpvarchar10否MRpvarchar10否MMpvarchar10否MSvarchar10否MDsgvarchar30
表4tb,clint,arrearage字段类型大小是否为主键是否允许为空ADatavarchar10是ATimevarchar10是ASmmvarchar50否AQunvarchar10AUntvarchar10AUntpvarchar10ASbtvarchar10AIdvarchar10否ANamevarchar10否
表5tb,provider
字段类型大小是否为主键是否允许为空PIdvarchar20是PNamevarchar20否PAddvarchar50PSgrvarchar10PPhnvarchar11PNmbvarchar10
表6tb,sell,detailed字段类型大小是否为主键是否允许为空DIDvarchar10是DNamevarchar20DSizevarchar10DAddvarchar10DNubvarchar20DSmmvarchar10否DRpvarchar10DMnyvarchar10DCidvarchar10否DCnamevarchar20DCdatavarchar10DDidvarchar10否
表7tb,stock_information
字段类型大小是否为主键是否允许为空
IIdvarchar10是
INamevarchar20
ISizevarchar10
IAddvarchar10
INubvarchar20否
ISnubvarchar10
IFpvarchar10
IMpvarchar10
IRpvarchar10
IDatavarchar10
5.系统实现
5.1窗体登录代码:
OptionExplicit
DimConnAsNewADODB.ConnectionDimrsAsNewADODB.RecordsetDimiAsInteger
PrivateSubcmdCancel_Click()UnloadMe
EndSub
PrivateSubcmdLogin_Click()DimstrUserNameAsString
DimstrPasswordAsString
strUserName=Trim(txtUserName.Text)
strPassword=Trim(txtPassword.Text)
IfstrUserName=""Then
MsgBox"请输入用户名",vbOKOnly+vbExclamation,""
txtUserName.SetFocus
Else
IfstrPassword=""Then
MsgBox"请输入密码",vbOKOnly+vbExclamation,""
txtPassword.SetFocus
Else
rs.Open"SELECT*FROMtb_userWHEREUserName='"+strUserName
+"'"
Ifi<3Andrs.EOF=TrueThen
MsgBox"用户名或密码错误,请重新输入",vbOKOnly+vbExclamation,""
rs.Close
txtUserName.SetFocus
txtUserName.Text=""
txtPassword.Text=""
Else
Ifi>=3Then
MsgBox"您输入用户名和密码的次数已经超过三次,本
次不能登录~",vbCritical+vbOKOnly,"错误"
UnloadMe
Else
IfTrim(rs.Fields
(1))=strPasswordThen'账号密码均正确,登
入系统
rs.Close
UnloadMe
MsgBox"欢迎进入珏缘信息管理系统~"
操作界面.ShowvbModal
Else
MsgBox"用户名或密码错误,请重新输入",vbOKOnly+vbExclamation,""
txtUserName.SetFocus
txtUserName.Text=""
txtPassword.Text=""
EndIf
EndIf
EndIf
i=i+1
EndIf
EndIf
EndSub
6.结论
通过数据库的需求分析、概念设计、逻辑模型设计等阶段基本完成了药店管理信息系统数据库的设计,同时也实现了数据库和VB的基本功能。
但是完整性相对较弱,在针对具体的药店应用时,还需进一步分析其管理需求。
当然,在具体设计中还可能遇到一些有待解决的问题。
7.参考文献
1,郑人杰,马素霞,殷人昆(软件工程概论,M,(北京:
机械工业出版社,2009.11(
2,王珊(数据库系统概论,M,北京:
高等教育出版社,2006.5
3,王珊(数据库系统简明教程,M,(北京:
高等教育出版社,2004(
4,王珊,冯念真(计算机应用系统的设计与开发,M,(北京:
高等教育出版社,1989.
5,范立南,刘天惠(SQLSever2000实用教程,M,(北京:
清华大学出版社,2004(
6,张南平,王伟,夏红霞(基于UML的B,S结构校务管理系统建模设计,J,(微机发展,2003(12)(