1、信息工程学院数据库课程设计论文题 目:小区物业管理数据库设计学 号:*专业班级:*姓 名:*指导老师:*完成日期:2011年6月25日小区物业管理数据库设计*(信息工程学院软件工程*级*班)【摘 要】随着计算机技术的不断普及和计算机数据处理功能不断增强,用计算机系统来对小区物业管理已经成了必要。利用数据库技术,开发了多用户小区物业系统程序。软件设计包括停车场的管理,小区设备的管理,住户日常维修事物的管理,以及收费管理。并对这些功能模块提供了查询和更新功能。小区物业管理系统可以提高物业管理的效率。关键字:功能模块 数据库设计 小区物业管理目 录1引言12需求分析12.1任务12.2系统功能模块1
2、2.3处理对象22.4 业务流程图32.5数据流程图32.6 数据字典53数据库结构设计73.1概念设计83.1.1分E-R图建立83.1.2全局/整体E-R图93.2逻辑设计93.2.1逻辑设计目标93.2.2建立关系模式102.2.3关系模式规范化处理102.2.4用户子模式建立102.2.5关系模式逻辑结构定义114数据库物理设计114.1物理设计阶段的目标和任务124.2数据存储125数据库实施与测试125.1数据库实施125.1.1数据库及数据库对象建立125.1.2数据入库125.2数据库测试136总结137附录13附录1业务流程图13附录1.1报修业务流程图13附录1.2收费业务
3、流程图14附录1.3停车业务流程图14附录1.4设备管理业务流程图14附录2 数据库的建立15附录2.1基本表15附录2.2索引16附录2.3视图17附录2.4触发器18附录2.5存储过程19附录3 SQL Server2008的测试24附录3.1查询24附录3.2更新251引言随着人民生活水平不断提高,人们对生活环境要求日益提高,尤其是对居住环境不断提出新的需求,为了适应这种形式,小区的经营者不仅首先要有坚实的硬件基础,还要有一套现代化的物业管理系统。而要实现这一功能,就职求物业管理者配备一套高效的管理住处网络系统,以便在小区内快速地发布和获取住处并以最快地速度响应用户的需求,及时为用户提供
4、服务,为住户提供一个高效、舒适的居住、生活环境。住宅小区的物业管理准确地讲应当是指对以居住为主要功用的物业进行管理。通过上网查询对小区物业管理的调查,了解到现在的小区物业管理仍停留在完全的人工管理阶段,小区管理处没有标准的住户存档信息。这种人工管理的方式不止大大的消耗了人力物力以及时间,效率更是很低。开发出合适现在的住户小区的小区物业管理系统,可以方便对小区里各种信息的管理,提高小区物业管理的查询效率和管理人员的工作效率。2需求分析需求分析简单地说就是分析用户的要求。需求分析是设计数据库的起点,需求分析的结构是否准确地反映了用户的实际要求,将直接影响到后面各个阶段的设计,并影响到设计结构是否合
5、理和实用。2.1任务(1)了解目前小区物业管理的现状。(2)通过网上查询的方式对小区物业管理的工作业务流程,并记录相关信息。(3)与指导教师交流个人想法,征求意见,改正不合理的地方,为下面的概念设计与逻辑设计奠定基础。2.2系统功能模块对物管中心来说小区的住户的报修,小区内停车场的管理、各项设备的使用管理,水、电和煤气费用收费等业务是必不可少的功能,物业管理包含许多方面,短时间内是无法将所有功能完全实现。因此我只是将上述的功能放到数据库设计中来实现。(1)物业管理员资料管理:对管理人员的基本信息的查询和更新。(2)住户资料管理:包括业主基本资料添加和管理模块。(3)报修管理:包括报修,维修和维
6、修费用的管理。(4)缴费管理:是该系统的最重要组成模块,包括主要收费项目和缴费业主信息,包括欠费标记。(5)停车车位管理:包括停车收费管理和信息管理。图 1 系统功能模块图2.3处理对象系统要处理的对象包括管理人员基本信息、住户基本信息、物业设备基本信息、停车场基本信息、住户投诉基本信息、住户维修基本信息、收费基本信息等七个方面,各个对象包括信息如下所示:系统功能模块管理人员信息管理人员姓名,性别,编号,管理项目等住户基本信息户主姓名,性别,住房编号物业设备管理设备借用时间,设备归还时间停车场管理停车开始时间,停车结束时间,按停车时间收费住户维修管理维修住户房号,维修住户姓名,维修信息状态,维
7、修次数收费管理住户维修收费,小区清洁收费,小区设备维修收费,收费记录2.4 业务流程图业务流程图就是用一些规定的符号及连线来表示某个具体业务处理过程。通过对小区物业管理的分析,得出主要有停车场业务流程图,收费业务流程图,设备管理业务流程图以及维修管理业务流程图。业务流程图:详见附录1。2.5数据流程图根据业务流程图画出数据流程图,顶层数据流程图以及具体数据流程图。下图为顶层数据流程图:第一层数据流程图:第二层数据流程图:P1 收费业务数据流程图P2 报修业务数据流程图P3 停车业务数据流程图2.6 数据字典数据字典是关于数据库中数据的描述,及元数据,而不是数据本身。数据流程图表达了数据和处理的
8、关系,数据字典则是系统中各类数据描述的集合,是进行详细的数据收集和数据分析所获得的主要成果。根据数据流程图,可以得出数据字典,主要包括数据项,数据结构。数据项是不可再分的数据单位。本系统中的数据项有以下几项:表1-1 小区物业管理系统数据项数据项编号数据项名称数据项定义数据类型大小I-1AdminNo管理员编号char20I-2AdminName管理员姓名char20I-3AdminSex管理员性别char20I-4ManageItem管理项目char20I-5AdminPhone管理员电话char20I-6Rno住房号char20I-7OwnerName户主姓名char20I-8OwnerS
9、ex户主性别char20I-9OwnerPhone户主电话char20I-10CheckInTime入住时间dateI-11EquNo设备借用编号char20I-12EquName借用设备名称char20I-13ELendTime设备借用时间dateI-14ERetTime设备归还时间dateI-15ParkNo停车编号char20I-16PStartTime停车开始时间dateI-17PEndTime停车结束时间dateI-18PCharge停车收费intI-19RepNum维修编号char20I-20RTimes维修次数intI-21RTime维修申请时间dateI-22Rcost维修费用
10、intI-23Cno1计费编号char20I-24Cname收费名称char20I-25CStartTime计费开始时间dateI-26CEndTime计费结束时间dateI-27Cused使用额intI-28CPrice收费单价intI-29Cno2收费编号char20I-30CCharge收费额intI-31CTime收费日期dateI-32CStatus缴费状态char2数据结构,反映了数据之间的组合关系,一个数据结构可以由若干个数据项组成,也可由若干个数据结构组成。本系统的数据结构包括超市货物信息,供应信息,销售信息等基本内容,主要有以下7项:表1-2 数据结构数据结构编号数据结构名数
11、据结构定义组成DS-1Administrator管理人员AdminNo,AdminPhone,ManageItem,AdminName,AdminSexDS-2RoomOwner住户RNo,OwnerName,CheckInTime,OwnerSex,OwnerPhoneDS-3ChargeItem收费项目Cno1,Cname,CStartTime,CEndTimeCused,CPrice,Cno2,CCharge,CTime,CStatusDS-4Equipment物业设备EquNo,EquName,ELendTime,ERetTimeDS-5RepairRecord维修记录RepNum,R
12、Times,RTime,RcostDS-6Park停车场ParkNo,PStartTime,PEndTime,PCharge3数据库结构设计主要包括概念设计和逻辑设计两个部分。3.1概念设计概念设计阶段主要是将需求分析阶段得到的用户需求抽象为信息结构(概念模型)的过程,它是整个数据库设计的关键(1)设计分E-R图,即各子模块的E-R图;(2)生成初步E-R图,通过合并方法,做到各子系统实体、属性、联系统一;(3)生成全局E-R图,消除冲突以及冗余等。3.1.1分E-R图建立在需求分析中,已经完成了数据流程图,每个分E-R图都对应了一组数据流程图,分E-R图中涉及的数据都已经收集在数据字典中,现
13、在就是要将这些数据从数据字典中抽取出来参照数据流图,标定分E-R图中的实体、实体的属性、标识实体的码,确定实体之间的联系及其类型。在数据字典中,“数据结构”、“数据流”、“数据存储”都是若干属性有意义的聚合,就体现了这种划分。可以先从这些内容出发定义E-R图,然后再进行必要的调整。本系统分为四个模块:收费管理,报修管理,设备管理,停车管理。其E-R图如下:图 3.1 收费业务E-R图图 3.2 维修业务E-R图图 3.2 维修业务E-R图图 3.3 维修业务E-R图3.1.2全局/整体E-R图各个局部应用所面向的问题不同,这就导致了各个分E-R图之间必定会存在许多不一致的地方,因此,合并分E-
14、R图时并不能简单地将各个分E-R图画到一起,而是必须着力消除各个分E-R图中的不一致,以形成一个能为全系统中所有用户共同理解和接受的统一的概念模型。合理消除各个分E-R图的冲突是合并分E-R图的主要工作与关键所在。消除冲突过程:属性冲突不存在,命名冲突在Charge和ChargeMangement两个表中存在,最后通过处理修改其中一个表的部分命名,以消除命名冲突全局E-R图如下:3.2逻辑设计3.2.1逻辑设计目标概念设计阶段是独立于任何一种数据模型的信息结构。逻辑设计阶段就是把概念结构设计好的基本E-R图转换为与选用的DBMS产品所支持的数据模型相符合的逻辑结构。具体内容包括数据组织(将E-
15、R图转换成关系模型、网状模型、层次模型。模型优化、数据库模式定义、用户子模式设计)3.2.2建立关系模式实体型转换为关系模式。实体的属性就是关系的属性,实体的码就是关系的码。对于实体间的联系则有以下不同的情况:一个m:n联系转换为一个关系模式。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为各实体码的组合。一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为n端实体的码。一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系
16、模式合并。管理人员(编号,姓名,性别,管理项目,联系电话)住户信息(住房号,户主姓名,性别,联系电话,入住时间)物业设备(设备编号,设备名称,借用人住房号,管理员编号,设备借用时间,设备归还时间)停车管理(停车编号,车主住房号,管理员编号,停车开始时间,结束时间,收费金额)维修管理(维修编号,维修住户房号,已维修次数,维修申请时间,维修费用,维修管理员编号)计费管理(计费编号,收费名称,计费开始时间,计费结束时间,使用额,收费,单价户主住房号,收费管理员编号)收费管理(收费编号,收费额,收费日期,缴费状态,户主住房号,收费管理员编号)2.2.3关系模式规范化处理在维修管理基本表和维修信息基本表
17、,投诉管理基本表和投诉信息基本表,收费管理基本表和收费信息基本表中存在部分数据依赖经过规范已经解决,其他表基本符合3NF2.2.4用户子模式建立表2-1 关系子模式编号用户子模式作用V-1AdminView便于查询和修改管理员的基本信息V-2ROView便于查询和修改住户的基本信息V-3EquView方便物业设备信息的查询和更新V-4ParkView方便车位信息的查询和修改V-5RepMView便于查询维修信息的状况V-6ChargeView便于查询计费信息V-7CMView方便收费信息的查询和修改2.2.5关系模式逻辑结构定义表2-2 各模式的名称,含义,具体结构定义模式名称含义备注管理人员
18、表编号,姓名,性别,管理项目,联系电话模式1住户信息表住房号,户主姓名,性别,联系电话,入住时间模式2物业设备表设备编号,设备名称,借用人住房号,管理员编号,设备借用时间,设备归还时间模式3停车管理表停车编号,车主住房号,管理员编号,停车开始时间,结束时间,收费金额模式4维修管理表维修编号,维修住户房号,已维修次数,维修申请时间,维修费用,维修管理员编号模式7计费管理表计费编号,收费名称,计费开始时间,计费结束时间,使用额,收费,单价户主住房号,收费管理员编号模式9收费管理表收费编号,收费额,收费日期,缴费状态,户主住房号,收费管理员编号模式104数据库物理设计主要包括数据存储位置、存储格式;
19、索引及索引类型。4.1物理设计阶段的目标和任务数据库的物理设计就是为逻辑数据模型选取一个最合适应用要求的物理结构的过程,在这个阶段中要完成确定数据库的物理结构,在关系数据库中主要是存取方法和存储结构。建立索引可以提高查询的效率,但是维护起来又造成很大的不方便,所以只对部分表中的主键建立索引4.2数据存储由于基本表Adminstrator,RoomOwner的主码AdminNo,RNo经常在查询条件和连接操作的连接条件中出现,且它们的值唯一,考虑在两个属性上建立唯一性索引。5数据库实施与测试主要包括数据库实施和测试两个部分。5.1数据库实施数据库实施阶段的目标是在SQL SEVER中建立数据库,
20、基本表,视图,索引,触发器以及存储过程5.1.1数据库及数据库对象建立主要包括:数据库、基本表、视图、索引、触发器以及存储过程;(1)建立数据库:Create database PropertyManagement(2)建立基本表:共有7张基本表,具体SQL语句见附录2(3)建立视图:共有7个视图,具体SQL语句见附录2(4)建立索引:共有2个索引,具体SQL语句见附录2(5)建立触发器:共有2个触发器,具体SQL语句见附录2(6)建立存储过程:共有?个存储过程,具体SQL语句见附录25.1.2数据入库系统包括物业设备管理、停车场管理、维修管理、收费管理五个功能模块,共有7张基本表, 采用的是
21、多条记录EXCEL批量导入,然后使用SQL Server 2008数据导入/导出功能,直接将数据导入到相应的基本表中。5.2数据库测试数据的测试主要是通过查询、插入、删除、修改操作来完成的,具体见附录3。6总结*7附录附录1业务流程图附录1.1报修业务流程图附录1.2收费业务流程图附录1.3停车业务流程图附录1.4设备管理业务流程图附录2 数据库的建立附录2.1基本表附录2. 11Create table Administrator(AdminNochar(20) primary key not null,AdminName char(20) not null,AdminSex char(2)
22、 check(AdminSex=男 or AdminSex=女)not null,ManageItem char(20)not null,AdminPhone char(20) not null);附录2. 12Create table RoomOwner(RNochar(20) primary key not null,OwnerName char(20) not null,OwnerSex char(2) check(OwnerSex=男 or OwnerSex=女)not null,OwnerPhone char(20)not null,CheckInTimechar(20) not n
23、ull);附录2. 13Create table RepairManagement(RepNum char(20)Primary key not null,RTimes int check(RTimes0 and RTimes9999)not null,RNochar(20) not null,OwnerName char(20) not null,AdminNochar(20) not null,RTime date,Rcost int not null,Foreign key (Rno) References RoomOwner(RNo),Foreign key (AdminNo) Ref
24、erences Administrator(AdminNo);附录2. 14Create table ParkManagement(ParkNo char(20)Primary keynot null,RNochar(20) not null,PStartTime date,PEndTime date,AdminNochar(20) not null,PChargeintnot null,Foreign key (Rno) References RoomOwner(RNo),Foreign key (AdminNo) References Administrator(AdminNo);附录2.
25、 15Create table Equipment(EquNo char(20) primary key not null,EquName char(20) not null,ELendTimedate not null,ERetTime date not null,AdminNochar(20) not null,Rnochar(20) not null,Foreign key (Rno) References RoomOwner(RNo),Foreign key (AdminNo) References Administrator(AdminNo);附录2. 16Create table
26、ChargeManagement(Cno1char(20) Primary key not null,Cname char(20) not null,CStartTime date,CEndTime date,Cused int not null,CPrice int not null,AdminNochar(20) not null,Rnochar(20) not null,Foreign key (AdminNo) References Administrator(AdminNo),Foreign key (Rno) References RoomOwner(RNo);附录2. 17Cre
27、ate table Charge(Cno2 char(20) Primary key not null,Cname char(20) not null,CCharge int not null,CTime date not null,CStatus char(2) check(CStatus = 是 or CStatus = 否) not null,Rnochar(20) not null,Foreign key (Rno) References RoomOwner(RNo);附录2.2索引附录2. 21create unique index AdNo on Administrator(Adm
28、inNo);附录2. 22create unique index RoomNo on RoomOwner(RNo);附录2.3视图附录2. 31Create View AdminView(AdminNo,AdminName,AdminSex,ManageItem,AdminPhone)AsSelect *From Administratorwith check option附录2. 32Create View ROView(RNo,OwnerName,OwnerSex,OwnerPhone,CheckInTime)AsSelect *From RoomOwnerwith check optio
29、n附录2. 33Create View ParkView(ParkNo,Rno,PStartTime,PEndTime,AdminNo,PCharge)AsSelectParkNo,ParkManagement.Rno,PStartTime,PEndTime,ParkManagement.AdminNo,PChargeFrom ParkManagement,Administrator,RoomOwnerWhere AdminiStrator.AdminNo=ParkManagement.AdminNo and RoomOwner.RNo=ParkManagement.RNo附录2. 34Cre
30、ate View EquView(EquNo,EquName,ElendTime,ERetTime,AdminNo,Rno)AsSelect EquNo,EquName,ElendTime,ERetTime,Equipment.AdminNo,Equipment.RNoFrom Equipment,Administrator,RoomOwnerWhere Administrator.AdminNo=Equipment.AdminNo and RoomOwner.Rno=Equipment.Rno附录2. 35Create View RepMView(RepNum,RTimes,RNo,Owne
31、rName,AdminNo,RTime,Rcost)AsSelect RepNum,RTimes,RepairManagement.RNo,RepairManagement.OwnerName,RepairManagement.AdminNo,RTime,RcostFrom RepairManagement,Administrator,RoomOwnerWhere Administrator.AdminNo=RepairManagement.AdminNo and RoomOwner.Rno=RepairManagement.Rno附录2. 36Create View ChaMView(Cno
32、1,Cname,CStartTime,CEndTime,Cused,CPrice,AdminNo,Rno)AsSelect Cno1,Cname,CStartTime,CEndTime,Cused,CPrice,ChargeManagement.AdminNo,ChargeManagement.RnoFrom ChargeManagement,Administrator,RoomOwnerWhere Administrator.AdminNo=ChargeManagement.AdminNo and RoomOwner.Rno=ChargeManagement.Rno附录2. 37Create
33、 View ChaView(Cno2,Cname,CCharge,CTime,CStatus,Rno)AsSelect Cno2,Cname,CCharge,CTime,CStatus,Charge.RnoFrom Charge,Administrator,RoomOwnerWhere RoomOwner.Rno=Charge.Rno附录2.4触发器附录2. 41Create Trigger Delete_T1On RoomOwnerinstead of DeleteAsdeclare R_No char(20)select R_No=RNofrom deletedDelete from Re
34、pairManagementwhere RNo=R_NoDeletefrom ChargeManagementwhere RNo=R_NoDeletefrom Chargewhere RNo=R_NoDeletefrom Equipment where RNo=R_NoDeletefrom ParkManagementwhere RNo=R_NoDeletefrom RoomOwnerwhere RNo=R_No附录2. 42Create Trigger Delete_T2On Administratorinstead of DeleteAsdeclare A_No char(20)selec
35、t A_No=AdminNofrom deletedDelete from RepairManagementwhere AdminNo=A_NoDeletefrom ChargeManagementwhere AdminNo=A_NoDeletefrom Equipment where AdminNo=A_NoDeletefrom ParkManagementwhere AdminNo=A_NoDeletefrom Administratorwhere AdminNo=A_No附录2.5存储过程附录2. 51Create Proc Pr_Administrator_QueryinNo varc
36、har(20)ASSelect*FromAdminViewWhereAdminNo=inNo附录2. 52Create Proc Pr_RoomOwner_QueryinNo varchar(20)ASSelect*FromROViewWhereRNo=inNo附录2. 53Create Proc Pr_Equipment_QueryinNo varchar(20)ASSelect*FromEquViewWhereEquNo=inNo附录2. 54Create Proc Pr_Park_QueryinNo varchar(20)ASSelect*FromParkViewWhereParkNo=
37、inNo附录2. 55Create Proc Pr_RepairManagement_QueryinNo varchar(20)ASSelect*FromRepMViewWhereRepNum=inNo附录2. 56Create Proc Pr_ChargeManagement_QueryinNo varchar(20)ASSelect*FromCMViewWhereCno=inNo附录2. 57Create Proc Pr_RepairManagement_QueryinNo varchar(20)ASSelect*FromRepairManagementWhereRepNum=inNo附录
38、2. 58Create Proc Pr_ChargeManagement_QueryinNo varchar(20)ASSelect*FromChargeManagementWhereCno1=inNo附录2. 59Create Proc Pr_Charge_QueryinNo varchar(20)ASSelect*FromChargeWhereCno2=inNo附录2. 510Create Proc Pr_RoomOwner_InsertRO_RNo char(20),RO_OwnerName char(20),RO_OwnerSex char(2),RO_OwnerPhone char(
39、20),RO_CheckInTimechar(20)AsInsert Into RoomOwnerValues(RO_RNo,RO_OwnerName,RO_OwnerSex,RO_OwnerPhone,RO_CheckInTime)附录2. 511Create Proc Pr_RoomOwner_DeleteOutNo varchar(20)AsDeleteFrom RoomOwnerWhere RNo=OutNo附录2. 512Create Proc Pr_Administrator_UpdateA_ANo char(20),A_AdminName char(20),A_AdminSex
40、char(2),A_ManageItem char(20),A_AdminPhone char (20)ASUpdate AdministratorsetAdminName=A_AdminName,AdminSex=A_AdminSex,ManageItem=A_ManageItem,AdminPhone=A_AdminPhonewhere AdminNo=A_ANo附录2. 513Create Proc Pr_Equipment_UpdateE_No char(20),E_EquName char(20),E_EquNo char(20),E_ELendTime date,E_ERetTim
41、e date,E_AdminNo char(20),E_Rno char(20)AsUpdate EquipmentsetEquNo=E_EquNo,EquName=E_EquName,ELendTime=E_ELendTime,ERetTime=E_ERetTime,AdminNo=E_AdminNo,Rno=E_Rnowhere EquNo=E_No附录2. 514Create Proc Pr_ParkManagement_UpdateP_No char(20),P_ParkNo char(20),P_RNo char(20),P_PStartTime date,P_PEndTime da
42、te,P_AdminNo char(20),P_PCharge intAsUpdateParkManagementset ParkNo=P_ParkNo,RNo=P_RNo,PStartTime=P_PStartTime,PEndTime=P_PEndTime,AdminNo=P_AdminNo,PCharge=P_PChargewhere ParkNo=P_No附录2. 515Create Proc Pr_RepairManagement_UpdateRM_No char(20),RM_RepNum char(20),RM_RTimes int,RM_RNo char(20),RM_Ower
43、Name char(20),RM_AdminNO char(20),RM_RTime date,RM_Rcost intAsUpdate RepairManagementset RepNum=RM_RepNum,RTimes=RM_RTimes,RNo=RM_RNo,OwnerName=RM_OwerName,AdminNo=RM_AdminNO,RTime=RM_RTime,Rcost=RM_Rcostwhere RepNum=RM_No附录2. 516Create Proc Pr_ChargeManagement_UpdateCMU_No char(20),CMU_Cno1char(20),CMU_Cnamechar(20),CMU_CStartTimedate,CMU_CEndTimedate,CMU_Cusedint,CMU_CPriceint,CMU