广东海洋大学 数据库课程设计 药品信息管理系统_第1页
广东海洋大学 数据库课程设计 药品信息管理系统_第2页
广东海洋大学 数据库课程设计 药品信息管理系统_第3页
广东海洋大学 数据库课程设计 药品信息管理系统_第4页
广东海洋大学 数据库课程设计 药品信息管理系统_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、药品信息管理系统1 系统分析 1.1需求分析:对药品信息管理主要需求就是对药品信息进行基本的管理,用户需要及时准确地掌握该诊所内现有的药品的基本信息(主要包括数量,单价,是否过期等)。同时,用户要求操作界面友好,操作简便,对数据库的操作安全可靠,药品从数据库中修改了,但还没结算时断电,要求数据库应该能恢复。1.2功能分析: 系统需要实现的主要功能包括查询,删除,增加,修改四部分,各功能具体如下表所示: 表1-1 系统的主要功能分析 2. 系统设计 2.1 绘制用例图设计系统功能药品信息管理系统一共包含3钟用户角色,分别是医生,售药员,和管理员,权限依次提高,医生权限是可以查询库存药品信息,提供

2、基本的用户管理功能(更改密码,更换用户),例图如下 医生用例图售药员的权限在医生的基础上,还具有药品管理的药品销售功能,用例图如下: 售药员用例图管理员具有所有权限,包括查询药品,增加药品条目,出售药品,清理药库(包括清除数量为0的药品,清除过期药品等)及所有的用户管理功能,用例图如下: 管理员用例图2.2 绘制系统流程图本系统需要对用户身份进行验证,验证通过后再判断用户是属于医生,售药员或者是管理员中的哪一个角色,根据角色判断用户可以使用系统中的相应操作功能这里以管理员的身份为例 ,其流程图如下: 系统流程图3. 数据库分析与设计3.1 数据库概念设计本系统一共设计规划出三个实体,分别是用户

3、信息实体,药品信息实体,药品销售实体。用户信息实体用于记录系统登录用户的信息,包括账号,密码,权限等相关信息其E-R图如下: 图3-1 用户信息实体药品信息实体是数据库的核心,记录了所存储的药品的基本信息,其E-R图如下:药品信息实体E-R图药品销售实体则记录了药品销售的相关信息,主要指药品的出售数量,出售总价等,其E-R图如下: 药品销售实体E-R图3.2 数据库逻辑结构设计根据设计好的各实体E-R图创建数据库的逻辑结构,数据库各表的结构如下。共3张表,分别是tb_medicine 和 tb_user,tb_saleTable. 表3-1 tb_medicine(药品基本信息表) 表3-2

4、tb_user(用户信息表) 表3-3 tb_saleTable(药品销售表)3.3 数据库物理结构设计3.4 系统类库设计药品信息管理系统中的类库主要设计如下:药品管理类 CManageMecdic:用于对药库进行管理,主要包括药品入库,药品的出售,药库的清理,以及为实现这些函数而加的成员函数。药品查询类 CMedicSearch:其成员函数主要包括一般查询,查询库中数量为0的药品,查询过期药品等。用户管理类CUser:主要设立了为完成以下功能的成员函数,如新增用户,删除用户,查询用户信息,修改用户密码等。药品类CMedic:相当于一结构体,只是为了给系统提供一个数据类型,以对药品进行必要的

5、管理,该类没有成员函数,该类一般作为CManageMedic和CMedicSearch类的一个成员变量。出售单类CSale:主要是给系统提供一个数据类型,以对药品出售进行有效的管理,该类也没有成员函数,该类作为CManageMedic类的一个成员变量。CMedicSet,CUserSer,CSaleSet类:用于与数据库中的表相连,它们从CRecordSer继承而来。一些对话框类:该系统许多地方都用到了对话框,这类对话框主要有CLlogInDlg,CChangPasswordDlg,CUserChangDlg,CStoreDlg,CCleanUpDlg,CSaleDlg等系统本身提供的框架类:

6、如CMainFrm,CMedicAdminDoc,CMedicAdminApp,CMedicAdmicView等。3.5 公用模块设计为了节省系统资源,实现代码重用,提高程序运行速度,可以将一些公用的数据信息放到模块中。本系统自定义了CManageMdedic,CMedicSearch,CSale,CUser,和CMedic类模块,而且从CRecordSet继承了CMedicSet,CUserSet,CSaleSer类,连接数据库中对应的表。a. 药品类 CMedic该类主要用于记录药品信息表中的各字段,主要包含一些成员变量,无成员函数。class CMedic public:CMedic()

7、;virtual CMedic();public:CStringm_MedicineID;CStringm_MedicineName;CStringm_MedicineClassification;CTimem_ProduceDate;CStringm_Produceplace;intm_MedicineNumber;CStringm_Description;floatm_UnitPrice;intm_QeulityAssurancePeriod;intm_LowestNumber;intm_HighestNumber;CStringm_ProduceCompany;b. 出售单类CSale出

8、售单类记录saleTable数据表中的字段值,主要包含一些成员变量,无成员函数class CSale public:CSale();virtual CSale();public:CStringm_MedicineID;CStringm_MedicineName;intm_MedicineNumber;floatm_MedicinePrice;c药品管理类CManageMedic该类主要实现药品的操作功能,包括药品入库,药品出售,和药品处理等,其成员变量和成员函数的定义如下:class CManageMedic public:void DeleteOverdueMedic();void Dele

9、teAllZeroNumber();CTime GetExpireTime();float CheckOut();BOOL Recover();BOOL DeleteFromSaleTable();BOOL ModifyFromSaleTable();BOOL AddToSaleTable();void SetSaleSet(CSaleSet* theSaleSet);void SetSale(CSale* theSale);void Import();void SetMedicSet(CMedicSet* theMedicSet);void SetMedic(CMedic* theMedic

10、);CManageMedic();virtual CManageMedic();protected:CMedic* m_theMedic;CMedicSet* m_theMedicSet;CSale* m_theSale;CSaleSet* m_theSaleSet;d药品查询类CMedicSearch该类实现药品的各种查询功能,其成员变量和成员函数的定义如下。class CMedicSearch public:void SearchOverdueMedic();void SearchZeroNumber();void SearchAll();void Search(CString str,i

11、nt flag);void SetMedicSet(CMedicSet* theMedicSet);void SetListCtrl(CListCtrl* theListCtrl);CMedicSearch();virtual CMedicSearch();protected:CMedicSet* m_theMedicSet;CListCtrl* m_theListCtrl;e用户管理类CUser该类实现用户的管理功能,包括用户登录,注册用户,查询用户,更换用户,修改密码,其成员变量和才成员函数的定义如下:class CUser public:void ModifyPassword(CUser

12、Set* theSet);CString GetPassword();CString GetAccount();void SetPassword(CString password);CString GetType();void SeekUserInfo(int typeRadio,CString str,CUserSet* theSet);void SetAccount(CString account);void DeleteUser(CUser* user,CUserSet* userSet);BOOL AddNewUser(CUser* newUser,CUserSet* theSet);

13、void SetAllMember(CString account,CString password,CString type,CString name);BOOL LogIn(CUserSet*);CUser();virtual CUser();protected:CString m_userAccount;CString m_userPassword;CString m_userName;CString m_userType;f记录集类CMedicSet,CUserSet,CSaleSet这3个类是以CRecordSet类为基类创建的,分别连接数据库中的medicine表,user表,sa

14、leTable表,通过Visual C+6.0提供的类创建向导对话框,可以实现这3个类的创建。以CMedicSet类为例,创建过程如下:在Visual C+6.0中,执行“Insert”“New Class“菜单命令,弹出”New Class“对话框,在其中设置创建的类CMedicSet和基类CRecordSet 如下图。同理CUserSet和CSaleSet创建过程也是这样。3.6 主界面设计系统采用标准的单文档程序界面,并采用窗口分隔技术将客户窗口试图分隔为左右两部分,分别用于显示用户信息和药品信息。药品信息视图类 CMedicListView以CListView类为基类,创建新的列表视图

15、类CMedicListView,通过列表的形式显示药品信息。在CMedicListView类的OnCreate函数中,创建列表项和表头,主要代码如下。int CMedicListView:OnCreate(LPCREATESTRUCT lpCreateStruct) if (CListView:OnCreate(lpCreateStruct) = -1)return -1;/ TODO: Add your specialized creation code heretheListCtrl=&GetListCtrl();ModifyStyle(0,LVS_REPORT);ASSERT(GetSt

16、yle() & LVS_REPORT);CString medicField9=药品代码,药品名称,药品类别,库存数量,出产公司,产地,出产时间,保质期(月),单价(元);for(int i=0;iInsertColumn(i,medicFieldi,LVCFMT_LEFT,70);theListCtrl-InsertColumn(8,medicField8,LVCFMT_LEFT,58);return 0;用户信息视图类CUserTreeView以CTreeView类为基类,创建新的树形视图类CUserTreeview,以树的形式显示用户类别及各类别下注册的用户。在CUserTreeView

17、类的PreCreateWindows函数中,设置树形控件的属性,主要代码如下:BOOL CUserTreeView:PreCreateWindow(CREATESTRUCT& cs) / TODO: Add your specialized code here and/or call the base classcs.style |= TVS_HASBUTTONS | TVS_HASLINES | TVS_LINESATROOT;return CTreeView:PreCreateWindow(cs);在CUserTreeView类的OnInitialUpdate函数中,设置医生,售药员,和管

18、理员三个树的根目录,并读取数据库中用户表中的数据,将相应类别的用户代码添加的树到子目录中。void CUserTreeView:OnInitialUpdate() CTreeView:OnInitialUpdate();/ TODO: Add your specialized code here and/or call the base classm_theTreeCtrl=&GetTreeCtrl();m_theImageList.Create(IDB_TREE_BITMAP,16,1,RGB(0,255,0);m_theTreeCtrl-SetImageList(&m_theImageLi

19、st,TVSIL_NORMAL);CString userTreeHeader3=医生,售药员,管理员;HTREEITEM userItem3;for(int i=0;iInsertItem(userTreeHeaderi,0,0,TVI_ROOT);m_theTreeCtrl-SetItemData(userItemi,(DWORD)i);CMedicAdminDoc* pDoc=(CMedicAdminDoc*)GetDocument();CUserSet* userSet=&pDoc-theUserSet;if(userSet-IsOpen()userSet-Close();userSe

20、t-Open();CLogInDlg logInDlg;logInDlg.DoModal();CUser* theUser=&pDoc-theUser;HTREEITEM thePoint;for(i=0;im_strFilter=UserClassification=+userTreeHeaderi+;userSet-Requery();for(int j=0;j+)if(userSet-IsEOF()break;if(userSet-m_UserAccount=theUser-GetAccount()HTREEITEM userSpecifics=m_theTreeCtrl-InsertI

21、tem(userSet-m_UserAccount+(当前用户),2,2,userItemi);m_theTreeCtrl-SetItemData(userSpecifics,(DWORD)j);thePoint=userSpecifics;elseHTREEITEM userSpecifics=m_theTreeCtrl-InsertItem(userSet-m_UserAccount,3,3,userItemi);m_theTreeCtrl-SetItemData(userSpecifics,(DWORD)j);userSet-MoveNext();m_theTreeCtrl-Select

22、(thePoint,TVGN_CARET);实现视图窗口的分隔窗口分隔采用静态分隔的方式。在主框架类CMainFrame的OnCreateClient函数中,通过CSplitterWnd类将客户窗口分隔为左右两部分,并分别对应前面创建的两个视图类,主要代码如下:BOOL CMainFrame:OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext) / TODO: Add your specialized code here and/or call the base classm_wndSplitter.CreateStatic

23、(this,1,2);/分割窗口为两列m_wndSplitter.CreateView(0,0,RUNTIME_CLASS(CUserTreeView),CSize(130,600),pContext);m_wndSplitter.CreateView(0,1,RUNTIME_CLASS(CMedicListView),CSize(700,600),pContext);return TRUE;/return CFrameWnd:OnCreateClient(lpcs, pContext);其中,m_wndSplitter在头文件中定义的CSplitterWnd类对象如下Protected:CSplitterWnd m_wndSplitter;3.7 登录模块设计当程序启动时,在主界面窗口出现之前,首先弹出登录对口框,如下图,用户需要输入账号,密码等信息,只有通过验证的用户才能进入系统,否则系统自动退出。登录对口框

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论