药品销售系统数据库课程设计.docx

上传人:牧羊曲112 文档编号:2094152 上传时间:2023-01-09 格式:DOCX 页数:23 大小:320.07KB
返回 下载 相关 举报
药品销售系统数据库课程设计.docx_第1页
第1页 / 共23页
药品销售系统数据库课程设计.docx_第2页
第2页 / 共23页
药品销售系统数据库课程设计.docx_第3页
第3页 / 共23页
药品销售系统数据库课程设计.docx_第4页
第4页 / 共23页
药品销售系统数据库课程设计.docx_第5页
第5页 / 共23页
点击查看更多>>
资源描述

《药品销售系统数据库课程设计.docx》由会员分享,可在线阅读,更多相关《药品销售系统数据库课程设计.docx(23页珍藏版)》请在三一办公上搜索。

1、塔里木大学信息工程学院课程设计前言随着计算机技术的发展和普及,各行各业的管理机构需要由计算机处理大量的信息。在我国药品品种繁多,规模甚大,以往的手工记载、查询操作容易出错且工作效率低,已经不能适应时代发展的要求,而且手工管理要浪费许多人力和物力,从管理的角度来看,对管理者会造成诸多的不便,还有可能疏忽一些细节。利用计算机进行药品管理,堵塞了药品的流失。规范了价格管理,避免了人为的物价损失,从而明显地提高了经济效益。将销售行为纳入规范化、公开化的轨道。21世纪是信息时代,在这个信息时代里竞争异常激烈,手工管理这种传统的管理方法必然被计算机为基础的信息管理所取代,所以实现药品的信息智能化管理特别重

2、要。因此,本人此次决定选择药品销售管理系统作为数据库课程设计。我在分析和设计这个系统时,参考了大量相关资料,程序设计采用了面向对象设计方法,这种成熟、高效的设计方法为系统开发带来了便利。本设计成功运用了Power Designer、SQL Server开发技术,设计出了药品销售系统。此次设计含有供应商信息,客户信息,药品信息,仓库信息,管理员信息,销售信息,供应信息,供应明细,销售明细,供应商往来账,退货返厂。 本设计实现了对这些信息的查询、插入、修改、删除等操作。工程概况2.1 项目题目药品销售系统数据库设计2.2 课程设计开发环境开发的操作系统是Windows XP。硬件、软件要求不高,目

3、前市场上的一般计算机软硬件都能满足系统开发要求。本次系统设计使用的前台开发工具是Power Designer。后台数据库使用的是SQL server2000。2.3 项目设计背景及意义开发药店药品销售管理系统能够提高药品销售管理的工作效率、扩大服务范围、增加药店收入、及时获取信息、减少决策失误、减少库存积压、提升员工的素质。能够及时提供药品基本信息、库存信息、销售业务信息和药店财务信息。在此基础上,通过对各种信息的综合分析,以改进药品品种、提高服务质量、满足前来购药顾客的不同要求,使药店管理向高质量、科学化发展。对提高仓储管理的工作效率和对市场的反应能力,能高效益、低库存、保证服务质量的满足药

4、店药品销售日常管理的需要,使其采用现代化管理手段以适应药店药品批发、零售业的发展。 正文该药品销售系统设计成功运用了Power Designer、SQL Server开发技术,设计出了对药品销售的管理信息。为了方便用户操作,在设置了系统功能,基本信息管理,查询等功能。在基本信息管理项的供应商信息、客户信息、药品信息、仓库信息等,可以进行添加修改删除等操作,在销售明细中可以查询销售信息,另外也可以查询供应信息及退货返厂的信息。 3.1 设计目的和意义3.1.1 设计目的通过本次数据库系统概论课程的学习与课程设计的制作,使我熟练掌握了Power Designer、SQL Server技术设计的基本

5、方法,并学会了SQL Server查询分析器和企业管理器的使用以及如何进行数据库的备份还原的基本知识,还学会了Power Designer的制图方法。同时通过两周的数据库课程设计的制作我还了解了数据库间的关系模型及SQL语言的特点,从而学会了如何建立基本表、定义、插入、删除与修改数据。通过该课程设计,使我对课本所学的知识得以巩固,将Power Designer、SQL Server开发技术相结合开发药品销售系统,这次设计使我们将理论知识和实践有机的相结合,达到了学以致用的真正目的。 3.1.2 设计意义使用Power Designer、SQL Server开发数据库。要求将程序设计完整,编写出

6、美观的界面、操作简单易懂的数据库程序。运用所学课程的知识分析解决实际问题,使我们掌握数据库设计的基本设计思想、通用方法和步骤。同时培养我们调查研究、查阅技术文献、资料、手册的动手能力。3.2 设计目标和总体方案3.2.1 设计目标药品销售系统的主要任务是对药品销售进行管理,使药店的销售管理方便化、智能化,向高质量、科学化发展。 3.2.2 设计总体方案药品销售系统的主要功能包括一下几个方面:(1)供应商信息管理:对药品销售系统中的药品供应商进行管理,方便业务联系。(2)药品信息管理:对销售的药品进行管理,能查询药品的各项信息,还可以对药品价格调整,药品信息修改。(3)仓库信息管理:对存储的药品

7、进行管理,可以清楚的了解药品的存储情况。(4)销售信息管理:对药品的销售情况进行管理,可以清楚的查询药品的销售额。(5)客户信息管理:对交易客户进行管理,可以查询、录入、修改客户信息。(6)管理员信息管理:对药品销售的员工进行管理,包括对员工的基本信息(如管理员的姓名、年龄、联系电话等)进行检索、录入和修改。3.3 设计方法和内容3.3.1 需求分析开发者首先要了解用户的需求,然后严格地定义该系统的需求规格说明书,这就是先要进行需求分析。需求分析是从客户的需求中提取出软件系统能够帮助用户解决的业务问题,通过对用户业务问题的分析,规划出系统的功能模块,即定义用例。这个步骤是对理解需求的升华,直接

8、关系到该系统的质量。药店的信息化实施是很紧迫的。依赖于系统的主要业务有:进药单登记与保存,库存盘点,药品信息整理与修改,销售药单整理统计,销售额统计等。经过开发者同客户的需求分析后,确定药品销售系统的功能模块包括:1)供应商信息管理 2)药品信息管理3)仓库信息管理 4)销售信息管理5)客户信息管理 6)管理员信息管理 根据需求分析,所设计系统的相关数据流程如下:1、基础数据录入:包括对供应商信息的录入,药品信息的录入,销售信息的录入。2、数据查询:对进药信息、售药信息、药品基本信息等的查询。3、数据分析:对药品销售情况的统计,即对一段时间内销售额情况的统计与图形分析。3.3.2 软硬件配置可

9、以根据用户量的大小选择不同的操作系统。当然,一般情况下,用户对微软Windows界面比较熟悉,因此,建议客户端都使用Windows 2000或者Windows XP操作系统。3.3.3 设计过程在创建表之前,本人首先绘制出了设计流程图,如下图:药品销售系统供应商信息管理药品信息管理仓库信息管理销售信息管理客户信息管理管理员信息管理此数据库包含一下表:客户信息表 (Customer)、分配表 (Distribution)、药品信息表 (Drugs)、管理员信息表 (Manager)、退货返厂表 (Return Fanchang)、销售明细表 (SaleDetail)、销售表 (Sales tab

10、le)、供应商往来帐 (Supplier current account)、供应商信息表(Suppliers)、供应信息表 (Supply)、供应明细表 (SupplyDetail)、仓库信息表 (Warehouse)。药品销售系统设计E-R图:在Power designer 中完成了药品销售系统的数据库设计,设计图如下:导出的表:下面介绍这些表的结构:(1)客户信息表 (Customer)(2)分配表 (Distribution)(3)药品信息表 (Drugs)(4)管理员信息表 (Manager) (5)退货返厂信息表 (Return Fanchang) (6)销售明细表 (SaleDet

11、ail)(7)销售信息表 (Sales table) (8)供应商往来帐 (Supplier current account)(9)供应商信息表 (Suppliers) (10)供应信息表 (Supply) (11)供应明细表 (SupplyDetail)(12)仓库信息表 (Warehouse)在Power designer中设计好后,可以生成脚本文件:(1)创建客户信息表 (Customer)的脚本文件如下:create table Customer ( ID char(8) not null, Full title char(30), Abbreviation char(10), Add

12、ress varchar(30), Respective area varchar(20), Telephone varchar(15), Contact person varchar(20), Bank account number varchar(18), Taxpayer registration varchar(20), constraint PK_CUSTOMER primary key (ID);(2)创建分配表 (Distribution)的脚本文件如下: create table Distribution ( War_ID char(8), ID char(8), Quanti

13、ty int);(3)创建药品信息表 (Drugs)的脚本文件如下: create table Drugs ( ID char(8) not null, Name varchar(20), Unit price money, Specifications varchar(20), Origin varchar(20), Packing char(15), Quantity int, Durability char(10), Authorized document number char(15), constraint PK_DRUGS primary key (ID);(4)创建管理员信息表

14、(Manager) 的脚本文件如下:create table Manager ( ID char(8) not null, Name varchar(20), Age int, Sex char(2), tel bigint, adress char(20), constraint PK_MANAGER primary key (ID);(5)创建退货返厂信息表 (Return Fanchang)的脚本文件如下: create table Return Fanchang ( ID char(8) not null, Return Date char(20), Returned goods qu

15、antity int, Unit price moeny, constraint PK_RETURN FANCHANG primary key (ID);(6) 创建销售明细表 (SaleDetail)的脚本文件如下: create table SaleDetail ( ID int not null, Dru_ID char(8), Sells the money shop varchar(20), Sales volume varchar(20) not null, Unit price money not null, Specification varchar(20), constrai

16、nt PK_SALEDETAIL primary key (ID);(7) 创建销售信息表 (Sales table)的脚本文件如下: create table Sales table ( Sells the money shop varchar(20) not null, ID int, Time DateTime, Has the amount money, constraint PK_SALES TABLE primary key (Sells the money shop);(8) 创建供应商往来帐 (Supplier current account)的脚本文件如下: create t

17、able Supplier current account ( Account serial number char(8) not null, ID char(8), Time varchar(15), Billing method varchar(10), Settlement amount money, constraint PK_SUPPLIER CURRENT ACCOUNT primary key (Account serial number);(9) 创建供应商信息表 (Suppliers)的脚本文件如下: create table Suppliers ( ID char(8) n

18、ot null, Full title varchar(20), Abbreviation varchar(10), Telephone varchar(15), Address varchar(20), Respective area varchar(10), Bank account number char(20), Taxpayer registration varchar(20), constraint PK_SUPPLIERS primary key (ID);(10) 创建供应信息表 (Supply)的脚本文件如下: create table Supply ( ID char(8)

19、 not null, Supply time char(20), Has the amount money, constraint PK_SUPPLY primary key (ID);(11) 创建供应明细表 (SupplyDetail)的脚本文件如下: create table SupplyDetail ( ID char(8) not null, Dru_ID char(8), Supply float not null, Unit price money not null, Specifications varchar(20), constraint PK_SUPPLYDETAIL p

20、rimary key (ID);(12) 创建仓库信息表 (Warehouse)的脚本文件如下:create table Warehouse ( ID char(8) not null, Name varchar(20), Administrator char(15), Category char(15), Area float, constraint PK_WAREHOUSE primary key (ID);3.4 设计创新和关键技术3.4.1 Power Designer设计 启动Power Designer,在工具栏中选择了Table工具,建立了Table表,他们分别是客户信息表 (C

21、ustomer)、分配表 (Distribution)、药品信息表 (Drugs)、管理员信息表 (Manager)、退货返厂表 (Return Fanchang)、销售明细表 (SaleDetail)、销售表 (Sales table)、供应商往来帐 (Supplier current account)、供应商信息表(Suppliers)、供应信息表 (Supply)、供应明细表 (SupplyDetail)、仓库信息表 (Warehouse)。在各个表中输入相应的信息,研究各个表之间存在的关系,确定主键辅键,调试并生成代码。3.4.2 SQL Server设计启动SQL Server查询分

22、析器,运行代码并生成表。进入企业管理器,生成Power Designer中建的关系图,新建一个数据库,点击右键,在所有任务中选择导入数据,按提示操作最后生成表,然后备份数据库。3.4.3 关键技术的应用程序运用了Power Designer、SQL Server2000软件开发技术。在Power Designer中建了12个关系图,运行后生成代码,在SQL Server查询分析器里调试,生成了12个表,利用SQL Server的企业管理器,新建数据库,导入数据,然后备份数据。3.5 调试及性能分析本设计在开始时错误很多,主要是在需求分析方面没有理解清楚,通过指导老师和同学的帮助,程序设计思路变

23、清晰了,经过多次的修改,发展到能运行的程度,它从开始单一的形式发展到了现在的形式多样而操作简单的程度。程序做出了对供应商信息、药品信息、仓库信息、销售信息、客户信息、管理员信息的管理,在此可以对基础数据录入,包括对供应商信息的录入,药品信息的录入,销售信息的录入。可以对数据进行查询,例如对进药信息、售药信息、药品基本信息等的查询。还可以进行数据分析,如对药品销售情况的统计,即对一段时间内销售额情况的统计与图形分析。以下是插入数据后的表:(1)客户信息表 (Customer)(2)药品信息表 (Drugs)(3)管理员信息表 (Manager)(4)退货返厂信息表 (Return Fanchan

24、g)(6)销售明细表 (SaleDetail)(7)销售信息表 (Sales table)(8)供应商往来帐 (Supplier current account)(9)供应商信息表 (Suppliers)(10)供应信息表 (Supply)(11)供应明细表 (SupplyDetail)(12)仓库信息表 (Warehouse)3.6 结果分析在设计中使用了Power Designer制作关系图,形象的突出了系统之间存在的内在关系,使用SQL Server成功的建立和备份了数据库,使设计者节约了时间,提高了设计的效率,最终成功的完成了该设计欲要达到的真正目的。在此次数据库课程设计中,我遇到了好

25、多问题难以解决,在建立关系的时候,由于没有清楚的理解需求分析,关系建反了。还有我的数据库表格已经建成了,但在生成代码时出现错误,系统提示是主键和外键设置不当,我仔细检查了Power Designer中的框图,还是没有发现错误,然后请教了老师,老师给我仔细分析了各个表之间的一对一,一对多等关系,在指导老师的帮助下,该问题最终得以解决。 致谢为期两周的课程设计结束了,此次课程设计中本人借助了上网查资料和图书来完成,在整个课程设计的过程中我遇到了很多问题,通过指导老师和同学们的帮助,进一步改进和完善了该系统的设计,我利用Power Designer制图,用SQL Server2000建数据库,完成了

26、此次的数据库设计。在这次数据库课程设计中,我进一步学习了Power Designer数据库开发技术,不仅仅用到了SQL Server2000,还用到了Power Designer开发技术,以及与之相关的计算机知识。在这里要感谢学校学院领导和老师们给我们实际操作的机会和为创造了良好的学习条件。在本次课程设计中,指导老师认真负责的工作态度,严谨的治学精神和深厚的理论水平都使我受益匪浅。无论在理论上还是在实践中,都给与我很大的帮助,使我得到不少的提高这对于我以后的工作和学习都有一种巨大的帮助。在系统开发过程中陈立平老师给予我们很大的帮助,帮助解决了不少的难点,使得系统能够及时开发完成,还有许多同学同

27、样给与了我不少的帮助,衷心的感谢陈立平老师和同学们的精心指导和帮助。实践是巩固所学知识最好的方法。这次的系统设计使我学到了很多知识和编程技巧。也使我自己的水平提升到了一个新的台阶。再次感谢给予我帮助的老师和同学们。参考文献1王鹏.数据库技术及其应用.第1版,北京:人民邮电出版社,2001年2月.2萨师煊,王珊.数据库系统概论.第一版,北京:高等教育出版社,1983.3邱玉辉主编.数据库实用技术.重庆西南师范大学出版社,2000.4胡铮.数据库管理.第1版,北京:华夏出版社,2006年1月.5李代平.中文SQL Server 2000数据库系统管理.第1版,北京:冶金工业出版社,2002年6月.

28、6夏邦贵,郭胜.SQL Server数据库开发入门与范例解析.第一版,北京:机械工业出版社: 第50页7蔡翠平.数据库技术-SQL.第1版,北京: 清华大学出版社,2002年1月.8C.J.Date.数据库系统导论.第一版,北京:机械工业出版社,2000.9王珊,陈红.数据库系统原理教程.第一版,北京:清华大学出版社,2005.10丁宝康,董健全.数据库实用教程.第二版,北京:清华大学出版社,2005.11张莉,王强,赵文,董莉.SQL Server数据库原理及应用教程.第二版,北京:清华大学出版社,2004.12耿冲.SQL Server2000数据库管理.第二版,北京:机械工业出版社,20

29、01.13章立民.SQL Server 2000 Transact_SQL 程序设计.第二版,北京:中国铁道出版社,2000.14朱克勤.数据库系统性能优化方法.第一版,北京:中国铁道出版社,2004.15宋世斌,李存华.SQL Server中存储过程技术的研究与应用.第二版,北京:电脑知识与技术学院,2007.16王洪香.基于SQL Server数据库完整性约束的几点探讨.第二版,北京:清华大学出版社,2006.18王新龙.存储过程应用研究.第一版,北京:中国铁道出版社,2006.19宋大伟,马凤娟,安庆森.SQL Server中如何在日志文件丢失时恢复数据库.第二版,北京:教育学院,200

30、5.20梁宾,胡天云.SQL Server中数据库表结构的动态修改.第一版,浙江:万里学院,2002.21王奇成.Sybase数据库的存储过程性能优化.第二版,北京:铁路计算机应用,2005.22张义德,于西俭.基于SQL Server的存储过程技术研究.第二版,北京:航空计算技术, 2001.23王洪香.基于SQL Server数据库完整性约束的几点探讨.第二版,北京:办公自动化,2006.24 耿文兰.SQL Server 数据库管理与开发.第1版.北京:电子工业出版社,2003年10月.25 刘大玮主编.QL Server 数据库项目案例导航.京清华大学出版社,2002:第33页-35页

31、26 刘赛锦.Transact-SQL 实例大全.第1版.北京:国防工业出版社,2002年1月:第7页27 牛勇.SQL Server编程篇.第1版.北京:电子工业出版社,2005年1月:第31页-74页28 丁宝康.数据库原理.第1版.北京:北京经济科学出版社,2004年1月:第51页-68页29 姜力.高群.SQL Server数据库设计与管理.第1版.北京:北京大学出版社,2006年8月:第49页-92页30 邱玉辉.数据库实用技术.第1版.重庆: 西南师范大学出版社,2000年12月:第25页附录A 程序代码/*=*/* DBMS name: Sybase AS Anywhere 9

32、*/* Created on: 2008-6-14 17:33:55 */*=*/if exists(select 1 from sys.sysforeignkey where role=FK_CUSTOMER_REFERENCE_MANAGER) then alter table Customer delete foreign key FK_CUSTOMER_REFERENCE_MANAGERend if;if exists(select 1 from sys.sysforeignkey where role=FK_DISTRIBU_REFERENCE_WAREHOUS) then alte

33、r table Distribution delete foreign key FK_DISTRIBU_REFERENCE_WAREHOUSend if;if exists(select 1 from sys.sysforeignkey where role=FK_DISTRIBU_REFERENCE_SUPPLYDE) then alter table Distribution delete foreign key FK_DISTRIBU_REFERENCE_SUPPLYDEend if;if exists(select 1 from sys.sysforeignkey where role

34、=FK_RETURN F_REFERENCE_SUPPLYDE) then alter table Return Fanchang delete foreign key FK_RETURN F_REFERENCE_SUPPLYDEend if;if exists(select 1 from sys.sysforeignkey where role=FK_SALEDETA_REFERENCE_DRUGS) then alter table SaleDetail delete foreign key FK_SALEDETA_REFERENCE_DRUGSend if;if exists(selec

35、t 1 from sys.sysforeignkey where role=FK_SALEDETA_REFERENCE_SALES TA) then alter table SaleDetail delete foreign key FK_SALEDETA_REFERENCE_SALES TAend if;if exists(select 1 from sys.sysforeignkey where role=FK_SALES TA_REFERENCE_CUSTOMER) then alter table Sales table delete foreign key FK_SALES TA_R

36、EFERENCE_CUSTOMERend if;if exists(select 1 from sys.sysforeignkey where role=FK_SUPPLIER_REFERENCE_SUPPLIER) then alter table Supplier current account delete foreign key FK_SUPPLIER_REFERENCE_SUPPLIERend if;if exists(select 1 from sys.sysforeignkey where role=FK_SUPPLY_REFERENCE_SUPPLIER) then alter

37、 table Supply delete foreign key FK_SUPPLY_REFERENCE_SUPPLIERend if;if exists(select 1 from sys.sysforeignkey where role=FK_SUPPLYDE_REFERENCE_DRUGS) then alter table SupplyDetail delete foreign key FK_SUPPLYDE_REFERENCE_DRUGSend if;if exists(select 1 from sys.sysforeignkey where role=FK_SUPPLYDE_RE

38、FERENCE_SUPPLY) then alter table SupplyDetail delete foreign key FK_SUPPLYDE_REFERENCE_SUPPLYend if;if exists( select 1 from sys.systable where table_name=Customer and table_type in (BASE, GBL TEMP) then drop table Customerend if;if exists( select 1 from sys.systable where table_name=Distribution an

39、d table_type in (BASE, GBL TEMP) then drop table Distributionend if;if exists( select 1 from sys.systable where table_name=Drugs and table_type in (BASE, GBL TEMP) then drop table Drugsend if;if exists( select 1 from sys.systable where table_name=Manager and table_type in (BASE, GBL TEMP) then drop

40、table Managerend if;if exists( select 1 from sys.systable where table_name=Return Fanchang and table_type in (BASE, GBL TEMP) then drop table Return Fanchangend if;if exists( select 1 from sys.systable where table_name=SaleDetail and table_type in (BASE, GBL TEMP) then drop table SaleDetailend if;if exists( select 1 from sys.systable where table_name=Sales table and table_type in (BASE, GBL TEMP) then drop table Sales tableend if;if exists( select 1 from sys.systable where table_name=Supplier current account an

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号