1、“管家婆”仓库管理系统数据库设计说明书 V1.0姓名 学号 组长07301160 是07274018 否07301161 否07301159 否1、引言1.1 预期的读者主要为本公司和承包方的阅读者:本公司阅读者包括:设计人员、开发人员等。承包方阅读者包括:业务人员、系统管理人员等。1.2 数据库说明我们使用的是当前流行的企业级数据库 oracle,使用版本为 10g。全局数据库名称为 GuanJiaPoORCL,开发用的表空间名是 GuanJiaPoSpace,操作的用户明为 GuanJiaPo,密码为 lq。1.3 目的和作用将业务分析,系统设计中对信息的描述进一步分析并加以总计,抽象出数
2、据集合(数据库表) 。对数据集合做进一步分析,确定集合之间的关系并最终形成数据库物理模型,以便开发人员建立物理数据库数据库设计2、数据库设计2.1 抽象数据对象2.1.1 系统主要业务分析根据业务流程分析我们从中抽象出几个数据集合:用户(包括秘书、采购员、销售员、后勤部、仓库管理员、系统管理员) ,商品的入库、出库情况和转借情况(入库申请、出库申请、转借申请、物品在仓库间的转移) ,仓库情况(仓库类别、仓库状态等相关信息) ,通过这几个集合实现物品在仓库间的合理分配。按照业务及系统功能简单总结数据对象: 用户 仓库存放物(商品、物品) 表单 仓库 系统管理员1.1.1 需求分析参考根据系统需求
3、分析内容进一步确定数据对象。由于系统需求分析中考虑到仓库存放物中商品(供出货和入仓用)和货品(供出借和归还用)间有一定的区别,所以将商品和物品分开描述,并提出单独的信息维护功能。其他数据对象没有变化。总结数据对象: 用户 系统管理者 商品 物品 表单 仓库1.2 数据库物理结构设计根据系统的分布式部署设计,数据库将部署到一部独立的计算机中。根据前期的分析,系统将有大量的数据存放入数据库。预留数据库空间 500m,日增长约3m,日志空间 1G,日增长 5m。1.3 数据库逻辑设计1.3.1 数据库设计命名规范1,表名命名规则多对多生成的关系表如果没有太多的实际意义,名字是两个相关实体名字中间加入
4、_后构成。例如 User_UserClass。 (如有特殊意义,按其特殊意义填写)2,表项命名规则代表表名的单词或单词简写作为字段名的开头,命名中其他的单词或简写间用_间隔,如用户表的主键字段为 U_ID 命名。1.3.2 数据库表名汇总表 2-1 数据库表数据库表名 中文名 文字说明Admin 系统管理员 保存系统管理员的信息IO_Form 出库入库申请 申请表单与货物的关系Form 申请表单 保存出库入库订单User 用户 保存用户的基本信息User-Class 用户-用户类型 用户与用户类型的关系User_Class 用户类型 保存用户职位Return_Borrow 借入归还表 申请表单
5、与物品的关系things 物品 保存物品的信息(用于转借)Things_Store 物品-仓库 物品与仓库间的关系store 仓库 保存仓库信息Product_Store 货物-仓库 货物与仓库的关系goods 货品 保存货物信息1.3.3 数据库表结构设计1.3.3.1 逻辑表结构 系统管理员:admin表 2-2 admin 表项中文 英文 数据类型 可否空 初始值 说明编号 A_ID Number 否 主键,流水自增姓名 A_Name Variable characters (100) 否联系方式 A_Conn Variable characters (20) 否账号 A_Account
6、 Variable characters (100) 否密码 end_time Variable characters (50) 否 出库入库申请(IO_Form)表 2-3 IO_Form 表项中文 英文 数据类型 可否空 初始值 说明编号 F_ID Number 否 主键,外键货物编号 G_ID Number 否 主键,外键货物数量 IO_Number INT 否 申请表单(Form) 表 2-4 申请 Form 表项中文 英文 数据类型 可否空 初始值 说明编号 F_ID Number 否 主键,流水自增用户编号 U_ID Number 否 外键提交日期 F_Date Date & Ti
7、me 否处理状态 F_State Variable characters (10) 否 值只有可能为:未处理,允许, 拒绝,推迟等候处理结果 F_Result Clob 否申请内容 F_Text Clob 否表单类型 F_Class Variable characters (20) 否 用户(User)表 2-5 user 表项中文 英文 数据类型 可否空 初始值 说明编号 U_ID Number 否 主键,流水自增姓名 A_Name Variable characters (100)否联系方式 A_Conn Variable characters (20) 否账号 A_Account Var
8、iable characters (100) 否密码 A_Pass Variable characters (50) 否 用户-用户类型(User_UserClass)表 2-6 User_Class 表项中文 英文 数据类型 可否空 初始值 说明编号 U_ID Number 否 主键,外键用户类型 User_Type Variable characters (20) 否 主键,外键 用户类型(User_Class)表 2-6 User_Class 表项中文 英文 数据类型 可否空 初始值 说明用户类型 User_Type Variable characters (10) 否主键 值只可能为:
9、供货员,出货员,后勤管理员,仓库管理员 货物表项表 2-2 货物表项中文 英文 数据类型 可否空 说明货物编号 G_ID Number 否 主键,流水自增货物名称 G_Name VARCHAR 否货物描述 G_Discribe CLOB 否货物数量 G_Number INT 否货物单价 G_Price FLOAT 否 货物仓库表项表 2-3 货品仓库表项中文 英文 数据类型 可否空 说明货物编号 G_ID Number 否 主键,外键仓库编号 S_ID Number 否 主键,外键存储数量 PS_Number INT 否 仓库表项 表 2-4 仓库表项中文 英文 数据类型 可否空 初始值 说明
10、仓库编号 S_ID NUMBER 否 主键,流水自增仓库地址 S_Add VARCHAR 否仓库类型 S_Type VARCHAR 否仓库状态 S_Style VARCHAR 否仓库容量 S_Size INT 否仓库类别 S_Class VARCHAR 否 物品-仓库表项 表 2-5 物品-仓库表项中文 英文 数据类型 可否空 说明物品编号 T_ID Number 否 主键,外键仓库编号 S_ID Number 否 主键,外键物品数量 TS_Number INT 否 物品表项 表 2-6 物品表项中文 英文 数据类型 可否空 说明物品编号 T_ID Number 否 主键,流水自增物品名称 T
11、_Name VARCHAR 否物品描述 T_Discribe CLOB 否物品现有数量 T_Number INT 否物品的库存数 T_Total INT 否 借入归还表项 表 2-6 借入归还表项中文 英文 数据类型 可否空 说明编号 F_ID Number 否 主键,外键物品编号 T_Name VARCHAR 否 主键,外键物品数量 RB_Number CLOB 否1.3.3.2 数据库表逻辑 ER 图图 2-1 逻辑 ER 图图中“ ”表示多对一关系,三叉线表示对应的多方表,多对多应该为“”。1.3.3.3 表之间的关联设计在数据库 ER 逻辑模型的基础上确定 ER 物理模型,通过主外键的
12、约束明确表之间的关系。该物理模型可直接映射到数据库中进行物理操作,以便据此建立数据库结构。ER 物理模型如下:图 2-2 物理 ER 图物理模型字段如下表:Table column Code description系统管理员编号 A_ID 主键索引姓名 A_Name联系方式 A_Conn账号 A_Account密码 A_Pass出库入库申请编号 F_ID 主键索引货物编号 G_ID 由货物表引用的外键,主键索引货物数量 IO_Number申请表单 编号 F_ID 主键索引用户编号 U_ID 由用户表引用的外键提交日期 F_Date处理状态 F_State处理结果 F_Result申请内容 F_
13、Text表单类型 F_Class用户 编号 U_Id 主键索引姓名 U_Name联系方式 U_Conn账号 U_Account密码 U_Pass用户-用户类型编号 U_ID 由用户表引用的外键,主键索引用户类型 User_Type 由用户类型表引用的外键,主键索引用户类型 用户类型 User_Type 由用户类型表引用的外键,主键索引货物编号 G_ID 主键索引货物名称 G_Name货物描述 G_Discribe货物数量 G_Number货品货物单价 G_Price货物编号 G_ID 主键索引,由货品表引用的外键仓库编号 S_ID 主键索引,由仓库表引用的外键货品-仓库存储数量 PS_Numb
14、er仓库编号 S_ID 主键索引仓库地址 S_Add仓库仓库类型 S_Type仓库状态 S_Style仓库容量 S_Size仓库类别 S_Class物品编号 T_ID 主键索引,由物品表引用的外键仓库编号 S_ID 主键索引,由仓库表引用的外键物品-仓库物品数量 TS_Number物品编号 T_ID 主键索引物品名称 T_Name物品描述 T_Discribe物品现有数量 T_Number物品物品的库存数 T_Total编号 F_ID 主键索引,由申请表单引用的外键物品编号 T_ID 主键索引,由物品表引用的外键借入归还物品数量 RB_Number外键关联说明:表 2-7 外键关联说明描述表名
15、 外键引用表 外键字段名 表关系 说明申请表单 编号 多对一出库入库申请货品 货物编号 多对一一个申请表单可以申请多种货物申请表单 用户 编号 2 多对一一个用户可以签订多个申请表单,一个申请表单只能由一个用户签订。用户 编号 多对多用户-用户类型 用户类型 用户类型 多对多一个用户可以有多个用户类型,一个用户类型可以被多个用户共有。申请表单 编号 多对多借入归还表物品 物品编号 多对多一个申请表单可以申请多个物品,一个物品可以被多个申请表单申请物品 物品编号 多对多物品仓库仓库 仓库编号 多对多一种物品可以存放至多个仓库,一个仓库可以存储多种物品。货品 货物编号 多对多货品-仓库仓库 仓库编
16、号 多对多一种货品可以存放至多个仓库,一个仓库可以存储多种货品。1.3.3.4 难点说明:不同权限申请表单时的复杂关系 在这个系统中我们发现,由于角色过多,导致订单的种类过多。如果细分的话,可以分出:采购员拥有入库申请表单的填写权利,出货员拥有出库申请表单的填写权利,后勤管理员拥有填写借入和申请物品表单的权利,仓库管理员拥有填写仓库申请表单的权利表单种类非常多,而且表面上看起来都是独立的。所以,刚开始我们为每一种表都建立了一个单独的表。这样虽然看起来逻辑清晰,但是,无形中为系统增加了很大的负担。图 2-3 物理 ER 图局部 1我们在建表的过程中发现,这几个表的基本项大致类似。所以,我们决定将所有的申请表格合成一张表,用一个字段“类别”来区分它们。这样,在不影响系统执行效率的情况下,减少了表的数量。