《SQLserver数据库》课程设计范例_第1页
《SQLserver数据库》课程设计范例_第2页
《SQLserver数据库》课程设计范例_第3页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

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

文档简介

1、1 概述1.1 课题简介书店书目书种繁多, 来源多样, 购买者众多, 图书信息、 供应商信息、 客户信息、 销售信息庞大, 不易管理。 因此,很有必要创建一个小型书店管理系统,以便于书店对图书的管理。1.2 设计目的应用对数据库系统原理的理论学习, 通过上机实践的方式将理论知识与实践更好的结合起来, 巩固所学知识。数据库应用 课程实践:实践和巩固在课堂教学中学习有关知识,熟练掌握对于给定结构的数据库的创建、 基本操作、程序系统的建立和调试以及系统评价。数据库原理 软件设计实践:实践和巩固在课堂教学中学习的关于关系数据库原理的有关知识和数据库系统 的建立方法,熟练掌握对于给定实际问题,为了建立一

2、个关系数据库信息管理系统,必须得经过系统调研、需求 分析、概念设计、逻辑设计、物理设计、系统调试、维护以及系统评价的一般过程,为毕业设计打下基础。1.3 设计内容运用基于 E-R 模型的数据库设计方法和关系规范化理论做指导完成从系统的分析到设计直至系统的最终实 现,开发小型书店管理系统,完成小型书店管理系统的全部功能。首先做好需求分析,并完成数据流图和数据字典。其次做概念分析,利用实体联系的方法将需求分析的用户需求抽象为信息结构,得到 E-R 图。然后就是逻辑结构设计,将 E-R 图转换为计算机系统所支持的逻辑模型2 需求分析2.1 功能分析首先,建立一些基本表(尽可能满足3N),对大部分基本

3、信息组合、存储;其次通过建立视图实现对冗余数据的有必要保留(查询并计算基本表属性得到新的作为视图属性)并实现对以下基本信息的显示。 图书信息:图书名称、订购数量、订购时间、订购单价、金额、出版社名称、作者名称;供应商名称等; 供应商信息:供应商名称、地址、电话,联系人;客户信息:客户编号、名称、年龄、性别、累计购书金额等; 销售信息:时间、销售名称、数量、销售单价、客户编号、客户名称、金额等。在此基础上进行以下目标查询, 由于有些查询常用且较复杂, 为了简化其应用, 所以将它们定义为存储过程。 查询当月书店销售金额、营业金额; (存储过程)查询某种图书库存数量; (存储过程) 查询当月销量最好

4、的图书信息; (存储过程)按供应商名称查询订购信息;(普通查询)查询购买次数超过 3次的客户信息。(普通查询)接着根据需要建立触发器、存储过程、索引,实现对数据库的优化。最后,进行过程功能的验证。允许具有 权限者对数据库进行数据更新和查询等合法操作。数据流图用流程图来描述处理过程与数据的关系数据流图如下:图2,1数据流图数据字典用数据字典来描述数据数据字典如下:数据项:表2.1数据字典数据 项名含义 说明别 名数据 类型长度取值范围取值含义与其他数据 项的逻辑关系图书编号唯一标识 每本书char800000000根据入库时间 先后编号有时与客 户编号作 为主码图书名称唯一标识 每种书书 名va

5、rchar30有时与供应 商组成主码作者名称每种书的 作者姓名char8出版社名 称每种书的 出版社名称char12供应商名 称唯一标识 供应商char12地址供应商的地址varchar50电话供应商的电话char700000009999999联系人通过联系人 书店与供应 商进行沟通char8订购时间每种书的 订购时间datetime应与图书称 与供应商 名称作为的主码 直接关联订购单价从供应商处 进货每种书 的每本价格int客户编号唯一标识char8000000000按购书先后有时与图客户编号书编号作 为主码客户名称客户姓名char8性别客户性别char2女或男年龄客户年龄int每年都要 增

6、加一岁的销售时间每本书的销售时间datetime与图书编号 和客户编号 作为的主码 直接关联销售单价每本书的 销售价格int数据结构:数据结构名称含义说明组成每种书指具有相同书名的书的集 合的基本信息图书名称、作者名称、出版社名称每本书指图书编号唯一标识的个体的归属图书编号、图书名称:供应商供应商的基本信息供应商名称、地址、电话、联系人供应基表每种书在何处订购的具体情况图书名称、供应商名称、订购单价、订购时间客户客户的基本信息客户编号、客户名称、性别、年龄销售基表每本书被谁买的具体请况图书编号、客户编号、 销售单价、销售时间概念结构设计概念结构设计的方法设计概念结构通常有四类方法:自顶向下,自

7、底向上,逐渐扩张以及混合策略。本系统采用的是自底向上的方法。即首先定义全局的概念结构的框架,然后逐步细化。根据自顶向下地进行需求分析然后再自底向上地进行概念设计。概念结构设计的步骤第一步:抽象数据;第二步:设计局部 E-R图;第三步:把各分 E-R图综合成总体E-R图,消除各种冲突;第四步:对总体 E-R图进行优化,消除冗余数据和冗余联系;抽象初步数据:(此处与优化后E-R图得出的实体联系属性很有可能不同)实体:图书、供应商、客户联系:图书订购关系、图书销售关系图书与供应商的关系是多对一的关系;图书与客户的关系是多对一的关系。属性: 图书的属性:图书编号、图书名称、出版社名称、作者名称、供应商

8、名称; 主码为图书编号供应商的属性:供应商名称、供应商地址、电话、联系人;主码为供应商名称 客户的属性:客户编号、姓名、性别、年龄; 主码为客户编号图书订购关系属性:供应商名称、图书编号、订购时间、订购单价; 主码为供应商名称和图书编号图书销售关系属性:客户编号、图书编号、销售时间、销售单价; 主码为客户编号和图书编号分E-R图:图书 E-R 图:供应商E-R图:客户E-R图:初E-R图:优化后的总E-R图:逻辑设计阶段逻辑设计阶段: 将系统 E-R 模型转换为关系模式, 并对给出的关系模式进行关系规范化处理 (尽量满足 3NF), 得到系统全部的关系模式,并标明主键、外键此部分一律采用英文命

9、名。然后进行用户外模式的设计,针对中国 用户,此处用中文命名。将 E R 模式转换为以下关系模式:1) book(#bname, writer_name, press_name);主键: #bname2. ) everybook (# bno, #bname) ;主键: #bno外键: #bname3) supplier (#supplier_name, address, telephone, contact) ;主键: #supplier_name4) customer (#cno, cname, sex, age);主键: #cno5) book_order(#bname, #suppli

10、er_name, #order_time, order_price, order_count);主键: #bname, #supplier_name, #order_time6) book_sell(#bno, #cno, sell_time, sell_price);主键: #bno发现这六个关系模式 3N 都满足。因为元组中都是不可分割的数据,且所有非主属性完全依赖其主码,且它 的任何一个非主属性都不传递于任何主关键字。用户外模式设计:基本信息视图的建立:1. 单本销售情况(图书编号,图书名称客户编号,客户名称,销售单价,销售时间) ;2. 同种销售情况(书名,销售数量,销售金额) ;3.

11、 客户信息(客户编号,客户名称、性别,年龄,累计购书金额) ;4. 供应商信息(供应商名称,地址,电话,联系人) ;5. 图书订购信息(图书名称,供应商名称,订购时间,订购数量,订购单价,订购金额,出版社名称,作者名 称);物理设计阶段物理设计阶段:为一个逻辑数据模型选取一个最适合应用环境的物理结构(存储结构与存取方法) ,数据库的物 理设计通常分为两步: A、确定数据库的物理结构; B、对物理结构进行时间和空间效率评价。建立小型书店管理系统创建数据库 book_shop_management- 创建小型书店管理系统create database book_shop_managementon

12、primary (name ='book_shop_management' ,filename = 'd:program filesmicrosoft sql servermssql.1mssqldatabook_shop_management.mdf' ,size =10mb ,maxsize =unlimited ,filegrowth =10 %)log on(name ='book_shop_management_log' ,filename = 'd:program filesmicrosoft sqlservermssql.1

13、mssqldatabook_shop_management_log.ldf' ,size =1mb,maxsize =5mb,filegrowth =3%)go截图得:对各个基本表的建立(包括了各种完整性约束)建立表 book- 建立表 bookcreate table book (#bname varchar ( 30) primary key writer_name char ( 8), press_name char ( 12)建立表 everybook- 建立表 everybookcreate table everybook ( #bno char ( 8) primary k

14、ey , #bname varchar ( 30) not null constraint fk_everybook_bnameforeign key references book ( #bname )建立表supplier- 建立表suppliercreatetable supplier(#supplier_name char( 12 )primarykey ,addressvarchar ( 50 )not null,telephonechar ( 7)notnull,contactchar ( 8) notnull)建立表customer- 建立表customercreatetable

15、 customer(#cno char ( 8) primarykey>cname char ( 8)not null,sex char( 2),age int>constraintck_customer_sexcheck( sex建立表book_order- 建立表book_ordercreatetable book_order (#bnamevarchar ( 30),#supplier_name char( 12 ),#order_time datetime>order_count int notnull,order_price int notnull,constrai

16、ntpk_book_orderprimarykeyin( ' 男 ' , ' 女' )( #bname , #supplier_name , #order_time )建立表 book_sell- 建立表 book_sellcreatetablebook_sell(#bnochar( 8)primarykey#cnochar( 8)notnull,sell_timedatetimesell_price int)建立视图建立基本信息视图:建立单本销售情况视图- 建立单本销售情况视图create view view_ 单本销售情况asselect book_sell

17、 . #bno as 图书编号 , #bname as 图书名称 book_sell . #cno as 客户编号 , cname as 客户名称 , sell_time as 销售时间 , sell_price as 销售单价 from book_sell , customer , everybookwhere everybook. #bno = book_sell . #bnoand customer . #cno = book_sell . #cno建立同种销售情况视图- 建立同种销售情况视图create view view_ 同种销售情况asselect 图书名称 as 书名 ,cou

18、nt ( 图书编号 ) as 销售数量 ,sum( 销售单价 ) as 销售金额from view_ 单本销售情况group by 图书名称建立客户信息视图- 建立客户信息情况create view view_ 客户信息select customer . #cno as 客户编号 ,cname as 客户名称 ,sex as 性别 ,age as 年龄 ,( select sum( sell_price ) from book_sellgroup by #cno ) as 累计购书金额from book_sell , customerwhere book_sell . #cno = custo

19、mer . #cno建立供应商视图- 建立供应商视图create view view_ 供应商信息asselect #supplier_name as 供应商名称 address as 地址 , telephone as 电话 , contact as 联系人from supplier建立订购信息视图- 建立订购信息视图create viewview_ 图书订购信息asselect book_order. #bname as图书名称#supplier_nameas 供应商名称 ,#order_timeas订购时间 ,order_priceas订购单价 ,order_countas订购数量 ,(

20、 order_price* order_count ) as订购金额press_nameas出版社名称 ,writer_nameas作者名称from book ,book_orderwhere book. #bname = book_order. #bname建立存储过程某种图书库存查询存储过程create procedure sp_ 某种图书库存查询-p1 为要查询的图书名称p1 varchar ( 30)asbeginselect 订购数 - 销售数量 as 库存from ( select sum( order_count ) as 订购数 , #bname as 书名 from book

21、_ordergroup by #bname ) as x , view_ 同种销售情况where x . 书名 =p1 and view_ 同种销售情况 . 书名 =p1 end某段时间内的销售业绩查询存储过程 建立本月业绩查询存储过程 由于不知其它信息,此处将销售金额与营业金额等同 营业金额 =营业额 =成本 +利润create procedure sp_ 查询某段时间内的业绩-p1 为起始时间 ,p2 为结束时间p1 datetime , p2 datetime as beginselect sum( 销售单价 ) as 销售金额 from view_ 单本销售情况 where 销售时间

22、>= p1 and 销售时间 <=p2 end go某段时间内的销售最好图书信息查询存储过程 建立某段时间内销售最好图书信息查询存储过程 create procedure sp_ 查询某段时间内销售最好的图书信息 p1 datetime , p2 datetime as begin select #bname as 图书名称 , writer_name as 作者名称 , press_name as 出版社名称 from ( select图书名称 as 书名 ,count ( 图书编号 ) as 销售数量 from view_ 单本销售情况 where 销售时间 >= p1

23、and 销售时间 <=p2 group by 图书名称 ) as x , book where #bname = 书名and 销售数量 >=all( select count ( 图书编号 ) from view_ 单本销售情况 where 销售时间 >= p1 and 销售时间 <=p2 group by 图书名称 ) end go建立触发器(另外 5 个表也建立相应曾删改触发器,不过此处从略,详情 见附件源代码)建立一个 customer 的操作审核表,并建立相关触发器,当向 customer 中插入、更新或删除记录时,生成一条操 作记录插入到该操作审核表中,内容包

24、括客户编号、客户名称、操作方式(插入/更新 /删除)和操作时间 建一个操作审核表create table customer_operate ( 客户编号 char ( 8)not null,客户名称 char ( 8)notnull,操作方式 char ( 4)notnull,操作时间 datetimenot null) 建立相关触发器create trigger trigger_customer_insert on customerfor insertasbegindeclare p1 char ( 8), p2 char ( 8) set p1 =( select #cno from in

25、serted )set p2 =( select cname frominserted)print 'insert:'select*from insertedinsertinto customer_operatevalues( p1, p2, ' 插入 ' , getdate ()endgocreatetrigger trigger_customer_deleteon customerfor deleteasbegindeclare p1 char ( 8), p2 char ( 8)set p1 =( select #cno from deleted )set

26、 p2 =( select cname from deleted )print 'deleted:'select * from deletedinsert into customer_operate values ( p1, p2, ' 删除 ' , getdate () end gocreate trigger trigger_customer_updateon customerfor updateasbegindeclare p1 char ( 8), p2 char ( 8)set p1 =( select #cno from deleted )set p

27、2 =( select cname from deleted )print 'inserted:'select *from insertedprint 'deleted:'select *from deletedinsert into customer_operate values ( p1, p2, ' 修改 ' , getdate () end建立索引(由于数据库比较小,没有必要建立索引)实现数据库(有附件源代码和该数据库源文件)过程功能验证向基本表插入适量如下数据并显示基本表信息#bno#bn ame00000001何以笙箫默0000000

28、2何以笙箫默00000003原来你还在这里00000004烈火如歌00000005烈火如歌00000006烈火如歌00000007微微一笑很倾城everybookbook#bn ameWriter_ namePress n ame何以笙箫默顾漫晋江出版社:原来你还在这里:辛夷坞起点出版社烈火如歌明晓溪晋江出版社微微一笑很倾城顾漫阅读出版社#bno#c noSell_timeSell_price00000001000000012013-6-162100000003000000022013-6-251900000007000000022013-7-92000000004000000032013-7

29、-92300000005000000042013-7-1918book_sell#c nocn amesexAge00000001吕鹏女1800000002孙鲁鲁女1800000003王肖雨女1900000004邵丽君女19customer#bn ame#supplier_ nameOrder_timeOrder_cou ntOrder_price何以笙箫默大旗2013-6-10212原来你还在这里大旗2013-6-20110烈火如歌红方2013-7-2110烈火如歌长城2013-7-329微微一笑很倾城高原2013-7-3111Book_order#suppileraddressteleph

30、o necon tact大旗上海1573234王平红方上海1734272李景长城P江苏1564323张艳丽高原郑州1242356殷风Suppilier注:此处插入数据应当book在everybook之前插入数据(外键)截图得:视图显示基本信息- 用显示视图基本信息select*fromview_单本销售情况select*fromview_供应商信息select*fromview_客户信息select*fromview_同种销售信息select*fromview_图书订购信息截图得:执行存储过程完成目标查询某种图书库存查询exec sp_ 某种图书库存查询 ' 烈火如歌 '本月业绩查询exec sp_ 查询某段时间内的业绩 '2013-7-1' , '2013-7-31'本月销售最好图书信息查询exec sp_ 查询某段时间内销售最好的图书信息 '2013-7-1' , '2013-7-31'截图得:用普通查询完成目标查询(两次查询同时显示)订购超 3 次

温馨提示

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

评论

0/150

提交评论