资源描述
DB2综合案例分析
需求分析任务
分析花店管理系统应用领域涉及内容,对涉及到领域各个应用信息规定和操作规定进行详细分析,形成需求分析阐明书。最重要是调查、收集信息、分析鲜花信息和鲜花购买流程。解决规定、数据安全性与完整性规定。
规定系统能有效、迅速、安全、可靠和无误完毕上述操作。并规定客户机界面要简朴明了,易于操作,服务器程序利于维护。
需求分析过程
为了以便花店管理,需要开发花店管理系统。便于花店从花市对鲜花采购,尚有花店对其店员信息,涉及店员编号,姓名和工资管理以及花店对其会员管理,以及顾客查询鲜花信息,涉及鲜花名称,价格和花语。
规定系统能有效、迅速、安全、可靠和无误完毕上述操作。并规定客户机界面要简朴明了,易于操作,服务器程序利于维护。
流程图及数据字典
1.业务流程分析
通过可行性分析和初步需求调查,抽象出该系统业务流程图。
⑴ 调查顾客需求
① 采购需求
l 功能:花店选取适合花市采购鲜花。
l 查询功能:
花市编号
花市名称
花市地址
②鲜花销售信息需求
l 查询功能:
u 花店编号
u 鲜花名称
u 销售额
③ 店员信息需求
l 查询功能:
u 店员编号
u 店员姓名
u 工资
④ 鲜花信息需求
l 查询功能:
u 鲜花名称
u 价格
u 花语
2.数据字典
将所有子系统所有细化。将所有顾客需求分析完毕之后,就要开始构造数据字典了。经分析之后,本系统要用到七个基本表:花市信息表,花店信息表,会员信息表,店员信息表,鲜花信息表,花店采购信息表和鲜花销售信息表数据构造定义如表2.1所示。
数据构造名
含义阐明
构成
花市
定义了花市关于信息
花市编号,花市名称,花市地址
花店
定义了花店关于信息
花店编号,花店名称,花店地址,花店电话
花店采购信息表
定义了花店采购关于信息
花市编号,花店编号
店员
定义了店员关于信息
店员编号,店员姓名,工资,花店编号
鲜花
定义了鲜花关于信息
鲜花名称,价格,花语
鲜花销售信息表
定义了鲜花销售关于信息
鲜花名称,花店编号,销售额
概念构造设计
数据抽象与局部视图设计
总体概念构造E-R图。
系统总体构造E-R图
逻辑构造设计
E-R图向关系模型转换
将总体概念构造E-R图转化成为关系模型。
花市(花市编号,花市名称,花市地址)
花店(花店编号,花店名称,花店地址,花店电话)
花店采购信息表(花市编号,花店编号)
店员(店员编号,店员姓名,工资,花店编号)
鲜花(鲜花名称,价格,花语)
鲜花销售信息表(鲜花名称,花店编号,销售额)
依照总体构造图设计各表构造,其相应标定义如下:
花市信息系统构造
字段名
数据类型
长度
约束
花市编号
char
10
主键
花市名称
varchar
20
不为空
花市地址
varchar
50
不为空
花店信息系统构造
字段名
数据类型
长度
约束
花店编号
char
10
主键
花店名称
varchar
20
不为空
花店电话
varchar
20
不为空
花店地址
varchar
50
不为空
花店采购信息系统构造
字段名
数据类型
长度
约束
花市编号
char
10
主键
花店编号
char
10
主键
店员信息系统构造
字段名
数据类型
长度
约束
店员编号
char
10
主键
店员姓名
varchar
20
不为空
工资
decimal
不为空
花店编号
char
10
外键
鲜花信息系统构造
字段名
数据类型
长度
约束
鲜花名称
varchar
20
主键
价格
decimal
不为空
花语
varchar
20
不为空
鲜花销售信息系统构造
字段名
数据类型
长度
约束
花店编号
char
10
主键
鲜花名称
varchar
20
不为空
销售额
decimal
不为空
数据库物理设计
索引建立
先给出索引有关定义,然后自己选取表或者属性建立索引(唯一索引、聚簇索引),规定表和索引存储在不同表空间里,写出有关SQL语句。
CREATE INDEX "USER".花市索引 ON "USER".花市 (花市名称 ASC) PCTFREE 10 MINPCTUSED 10 ALLOW REVERSE SCANS PAGE SPLIT SYMMETRIC COLLECT SAMPLED DETAILED STATISTICS ;
CONNECT RESET;
CREATE INDEX "USER".店员索引 ON "USER".店员 (店员姓名 ASC) PCTFREE 10 MINPCTUSED 10 ALLOW REVERSE SCANS PAGE SPLIT SYMMETRIC COLLECT SAMPLED DETAILED STATISTICS ;
CONNECT RESET;
表空间建立
connect to ag02wmn;
create regular tablespace dms02 managed by database
using (file 'd:\dms\dms02' 14) extentsize 2;
create long tablespace dms03 managed by database using (file 'd:\dms\dms03' 728) extentsize 8;
create regular tablespace dms04 managed by database using (file 'd:\dms\dms04' 22) extentsize 2;
create regular tablespace dms05 managed by database using (file 'd:\dms\dms05'
16) extentsize 2;
create regular tablespace dms06 managed by database using (file 'd:\dms\dms06'
40) extentsize 4;
create regular tablespace sms01 managed by system using ('d:\sms\sms01','d:\sms\sms02') extentsize 4;
数据库管理与维护
安全性及并发性
权限分派
建立三个顾客:user1,user2,user3
(1) 使第一种顾客user1和db2admin一起成为admin构成员,使admin具备SYSADM权限。可以对所有表进行操作。
(2)使第二个顾客user2拥有DBADM权限。
(3)将创立表之一上所有特权授予给自己建立顾客user3。
(4)为 鲜花信息表 设立RR隔离级,防止顾客读取信息时浮现丢失更新、脏读、不可重复读、幻象。
角色表:
编号
角色
可操作对象
可操作权限
所属成员顾客
1
dbo
所有数据库对象
所有操作
User1、db2admin
2
Public
鲜花信息表、鲜花销售信息系统表、花店信息系统
Select
User2、user3
备份与还原设计
每周日晚上11:30对sample数据库进行一次联机完全备份,然后在周一至周六明天晚上11:30对sample数据库进行一次联机差别增量备份。
1、在不同途径下创立两个文献夹 d:\db2bak\ 、d:\db2log 分别存储备份数据及日记文献
2、备份前修改日记模式为归档日记模式:db2 update db cfg using logarchmenth1 disk:\db2log\ 然后断开所有连接,再重新连接数据库进行备份
3、脱机完全备份:db2 backup db sample to d:\db2bak\ 记下时间戳
4、周日在线完全备份,记住时间戳:db2 backup db sample online to d:\db2bak\
5、进行周一增量备份,记住时间戳:db2 backup db sample online incremental delta to d:\db2bak\
6、进行周三增量备份,记住时间戳db2 backup db sample online incremental delta to d:\db2bak\
……
*若浮现数据库崩溃,则恢复数据库:
在完全备份时同步备份了日记文献。在进行还原时,要从备份映像还原日记文献。
还原近来一次增量备份:Db2 restore db sample incremental from d:\db2log\ taken at 时间戳
还原全量备份:db2 restore db sample taken at 时间戳 logtarget d:\db2log\
前滚恢复:
Db2 rollforward db sample to end of logs and stop
即可恢复数据库
数据迁移
将旧电脑Windows 操作系统上数据迁移至新电脑Linux操作系统中,不同操作系统之间迁移 DB2 数据库操作办法:
1、登录 Windows ,使用 db2move 命令将源数据库(htdctr)数据导出至指定文献夹 G:\db2move\htdctr 下。
2、登录 Windows ,使用 db2look 命令将数据库 DDL 导出至指定文献夹 G:\db2look\htdctr 下。 3、登录 Windows ,使用 ftp 命令登录 Linux 服务器(IP:172.168.16.105),将 DDL 脚本 G:\db2look\htdctr\db2look_htdctr.sql 上传至 Linux 服务器指定途径下:home/db2admin/dbback/db2look/htdctr,注意,上传 DDL 脚本时候必要使用 ASCII (asc)模式进行数据传播,否则背面执行该脚本会报错:DB21007E 读取该命令时已到达文献末尾。
4、登录 Windows ,使用 ftp 命令登录 Linux 服务器(IP:172.168.16.105),将 导出数据文献 G:\db2move\htdctr\* 所有上传至 Linux 服务器指定途径下:home/db2admin/dbback/db2move/htdctr,注意,上传 db2move.lst 脚本时候必要使用 ASCII (asc)模式进行数据传播,否则背面执行该脚本会报错:DB21007E 读取该命令时已到达文献末尾。上传 *.ixf、*.001 和 *.msg 文献时候必要使用二进制模式(bin)进行数据传播。
5、使用 telnet 命令登录 Linux 服务器,切换至指定途径:home/db2admin/dbback/db2look/htdctr,创立数据库 htdctr,完毕之后执行 DDL 脚本,创立数据库对象
6、在 Linux 服务器上使用 load 命令装载数据
至此,数据库迁移顺利完毕。
总 结
在这个学期咱们学习使用IBM DB2应用程序,并应用了SQL语言,并且对数据库创立、修改、删除办法也有了一定理解。为了更好巩固和加强课本所学知识,并把所学东西转化为实际应用,在这里我进行花店管理系统数据库设计。
通过把花店管理系统构造以及采购信息尚有鲜花,店员有关信息制成表格,输入到数据库中,使之可以进行查询、修改、删除并且与花店管理系统执行相似操作。需求分析阶段就是要研究我所作花店管理系统详细分类和实行过程流图。概念设计阶段要完毕数据抽象与局部视图设计尚有视图集成,逻辑构造设计阶段要把E-R图转化为关系模式,最后就是要维护数据库。
通过这次课程设计,对数据库关于知识纯熟掌握,并为毕业设计打好了基本。
展开阅读全文