《酒店客房信息管理系统的设计与实现.doc》由会员分享,可在线阅读,更多相关《酒店客房信息管理系统的设计与实现.doc(36页珍藏版)》请在三一办公上搜索。
1、指导教师对课程设计(论文)的评语(工作态度、任务完成情况、能力水平、设计说明书(论文)的撰写和图纸质量等):成绩 指导教师签字 年 月 日目 录第一章 需求分析41.1开发背景41.2功能描述41.3 业务流程分析5第二章 数据流程分析62.1数据流程图62.2 数据字典6第三章 概念模型设计8第四章 逻辑模式设计和优化9第五章 物理设计和实施115.1 创建数据库115.2 程序以及调试和使用说明13第六章 课程设计心得体会.32参考文献.33第一章 需求分析1.1开发背景90年代中期,由于Internet 的迅速普及,使Intranet成为Internet技术在企业管理信息系统中的应用和延
2、伸,形成了集计算机,计算机网络、数据库、分布式计算等于一体的信息技术综合体,它打破了时间和地域的界限,使信息交流变得快捷、准确,为建立现代企业管理信息系统提供了充足的条件。企业信息管理系统在此基础上延伸、扩展,使之上下、内外全面贯通。引入Internet后,形成了新型的浏览器/服务器(Browser/Server)结构,而传统的客户机/服务器(Client/Server)结构在这方面就远不及B/S结构。 近年来,宾馆业迅猛发展,市场的竞争日趋激烈,全面提高宾馆的软件管理水准,已成为宾馆业发展的当务之急。尤其是对于星级宾馆,既需要完成前台的一些服务工作,还需要完成后台的管理工作。然而,传统的人工
3、管理模式已经远远不能满足有效、快捷地处理经营中产生的大量信息数据的需要,从而使得企业决策层无法及时、准确地掌握一线资料,继而影响对市场进行正确地分析和预测。像沿海城市三星级以上宾馆引进外方管理,使小部分宾馆管理水准几乎接近或达到国际水平。但对占80%以上的广大中小型宾馆来说,是难以做到的。因此,欲在竞争中甩开对手,取得优势,必须在经营、管理、产品、服务等方面具备独到之处。而对宾馆的经营状况起决定作用的是客房的管理。简单的服务标准已不是制胜的锦囊,只有管理做到最细微之处,才能让顾客体会到宾馆服务的高标准、高质量,而准确、快速、周全往往就是最基本的成功要素。传统的管理方法已经不能适应现代社会的需要
4、,因此采用电脑管理业务、财务等诸多环节已成为推动宾馆业迅速发展的先决条件,宾馆客房管理信息系统是各大中小型宾馆所需要使用的一个管理系统。客房管理系统是典型的信息管理系统,其开发主要包括后台数据库的建立和维护以及应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的数据库,而对于后者则要求应用程序功能完备,操作简单等,该系统的是终目的方便员工查阅。1.2功能描述经过调研及分析,客房管理信息系统主要完成以下功能:(1)客房信息输入包括每间客房的大小级别、地理位置、预设租金等信息。(2)客房信息查询用于及时掌握客房的安排情况。(3)前台操作员管理用于设置前台管理员的密码和基本
5、信息。(4)客房预订处理各类客户预订要求,预订可以通过各种方式进行(如电话、e-mail、传真等)。前台需要根据当前客房入住情况,及时反馈给客户预订结果。(5)入住登记客户实际入住时,需要及时登记客户信息,以便今后查询。(6)房客查询可以根据各种信息查询房客是否入住及入住情况。(7)收费管理包括入住的定金、各类其他消费情况和最终的结账管理。1.3 业务流程分析业务流程分析 如图1所示。图1 业务流程图第二章 数据流程分析 2.1数据流程图数据流程图如图2所示。 维修信息调整房间维修/报修房间提醒 客房信息 预定 客房信息 客房状态入住退房客人 客人信息 入住登记 帐务信息财务现开 入住信息 图
6、2 数据流程图 2.2、数据字典(1) 数据流编号:D001数据流名称:预订数据流来源:客人数据流去向:预订登记包含的数据项:客房号,客房类型,定金,预订方式,客人姓名,客房状态(2) 数据流编号:D002数据流名称:客房状态数据流来源:客房数据流去向:预订登记包含的数据项:客房号,定金,预订方式,客人姓名,客房状态(3) 数据流编号:D003数据流名称:客人信息登记数据流来源:预订登记数据流去向:客人信息包含的数据项:客房号,客人姓名,客人性别(4) 数据流编号:D004数据流名称:客人入住数据流来源:客人预订产生入住登记数据流去向:入住登记包含的数据项:客房号,客人姓名,客房类型,楼层,价
7、格(5) 数据流编号:D005数据流名称:删除客人记录数据流来源:入住登记数据流去向:客人退房包含的数据项:客房号,客房类型,楼层,价格(6) 数据流编号:D006数据流名称:客人消费数据流来源:客人退房数据流去向:消费包含的数据项:客房号,客人姓名,客人餐费,定金,价格,总消费(7) 数据流编号:D007数据流名称:客房信息数据流来源:客人退房数据流去向:客房包含的数据项:客房号,客房类型,楼层,价格第三章 概念模型设计系统的总ER图如图3所示。 图3 总ER图第四章 逻辑模式设计和优化(1) 客房信息表1 客房信息客房号客房类型楼层价格 nvarchar(20)nvarchar(20)nv
8、archar(10)int(2) 客人信息表2 客人信息客房号客人姓名客人性别 nvarchar(20)char(10)char(3)(3) 客人预订表3 客人预订客房号定金预订方式客人姓名客房状态nvarchar(20)intnvarchar(20)char(10)nvarchar(20)(4) 客人入住表4 客人入住客房号客人姓名客房类型楼层价格nvarchar(20) nvarchar(20)nvarchar(20)nvarchar(20)int(5) 客人消费表5 客人消费客房号客人姓名客人餐费定金价格nvarchar(20) char(10)intintint第五章 物理设计和实施
9、5.1 创建数据库得到系统逻辑模型后,就该进行数据库的物理设计和实施数据库了,物理设计主要是要确定数据库的存储路径、存储结构等,可以采用系统的默认设置。数据库实施主要包括在具体的DBMS中创建数据库和表的过程,本设计所选用的DBMS为SQL SERVER2005,有关创建数据库和关系表的SQL语句如下所示:(1) 创建数据库/*=*/ create database 酒店客房数据库;/*=*/create database 酒店客房信息管理系统go(2)创建数据库的表/*=*/ 客房信息表/*=*/create table 客房信息(客房号 nvarchar(20),客房类型 nvarchar
10、(20),楼层 nvarchar(10),价格 int, primary key(客房号);/*=*/客人预订表/*=*/create table 客人预订(客房号 nvarchar(20),客房类型 nvarchar(20),定金 int,预订方式 nvarchar(10),客人姓名 char(10),客房状态 nvarchar(10),primary key (客房号),foreign key (客房号) references 客房信息(客房号),);/*=*/客人信息表/*=*/create table 客人信息(客房号 nvarchar(20), 客人姓名 char(10), 客人性别
11、 char(3), primary key (客房号),foreign key (客房号) references 客人预订(客房号);/*=*/客人入住表/*=*/create table 客人入住(客房号 nvarchar(20),客人姓名 char(10),客房类型 nvarchar(20),楼层 nvarchar(10),价格 int,primary key (客房号),foreign key (客房号) references 客房信息(客房号),);/*=*/客人消费表/*=*/create table 客人消费(客房号 nvarchar(20), 客人姓名 char(10), 客人餐
12、费 int,定金 int,价格 int,总消费 int,primary key (客房号),foreign key (客房号) references 客人入住(客房号); 5.2 程序以及调试和使用说明 (1)登陆界面图1 登陆界面private void 系统管理员_Click(object sender, EventArgs e) Form1 e2 = new Form1(); e2.Show(); private void 前台管理员_Click_1(object sender, EventArgs e) Form14 e3 = new Form14(); e3.Show(); priv
13、ate void客人查询_Click(object sender, EventArgs e) Form15 u15 = new Form15(); u15.Show(); private void 退出_Click(object sender, EventArgs e) this.Close(); Application.Exit(); (2)后台管理员登录界面图2 后台管理员登陆界面private void 登陆系统button_Click(object sender, EventArgs e) if (textUserName.Text = | textPassword.Text = )
14、MessageBox.Show(输入登录信息不完整,请重新输入!, 信息提示, MessageBoxButtons.OK, MessageBoxIcon.Information); else string ConStr = server=左-PC;uid=u3;pwd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); string SqlStr = select * from 操作用户1 where 用户姓名= + textUserName.Text + and 用户密码= + textPassword.T
15、ext + ; SqlDataAdapter ada = new SqlDataAdapter(SqlStr, con); DataTable dt = new DataTable(); ada.Fill(dt); int i = dt.Rows.Count; if (i 0) 主界面 a = new 主界面 (); a.Show(); else MessageBox.Show(用户名或密码不正确,请重新输入!, 信息提示, MessageBoxButtons.OK, MessageBoxIcon.Information); private void 退出系统button_Click(obje
16、ct sender, EventArgs e) this.Close(); Application.Exit(); (3)后台管理员主界面 图3 后台管理员主界面(4)前台管理员登陆界面图4 前台管理员登陆界面 private void button1_Click(object sender, EventArgs e) if (textUserName.Text = | textPassword.Text = ) MessageBox.Show(输入登录信息不完整,请重新输入!, 信息提示, MessageBoxButtons.OK, MessageBoxIcon.Information);
17、else string ConStr = server=左-PC;uid=u3;pwd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); string SqlStr = select * from 操作用户2 where 用户姓名= + textUserName.Text + and 用户密码= + textPassword.Text + ; SqlDataAdapter ada = new SqlDataAdapter(SqlStr, con); DataTable dt = new DataTable(
18、); ada.Fill(dt); int i = dt.Rows.Count; if (i 0) 主界面1 a1 = new 主界面1(); a1.Show(); else MessageBox.Show(用户名或密码不正确,请重新输入!, 信息提示, MessageBoxButtons.OK, MessageBoxIcon.Information); (5)客房信息录入 图5 客房信息录入private void button1_Click(object sender, EventArgs e) if (textBox1.Text = | textBox2.Text = | textBox3
19、.Text = | textBox4.Text = ) MessageBox.Show(输入信息不完整,请重新输入!, 信息提示, MessageBoxButtons.OK, MessageBoxIcon.Information); else string ConStr = server=左-PC;User id=u3;pwd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); StringBuilder strSQL = new StringBuilder(); strSQL.Append(insert i
20、nto 客房信息(客房号,客房类型,楼层,价格); strSQL.Append( values( + textBox1.Text.Trim().ToString() + , + textBox2.Text.Trim().ToString() + , + textBox3.Text.Trim().ToString() + , + textBox4.Text.Trim().ToString() + ); using (SqlCommand cmd = new SqlCommand(strSQL.ToString(), con) con.Open(); cmd.ExecuteNonQuery();
21、con.Close(); con.Dispose(); MessageBox.Show(客房信息添加成功!, 信息提示, MessageBoxButtons.OK, MessageBoxIcon.Information); textBox1.Text = ; textBox2.Text = ; textBox3.Text = ; textBox4.Text = ; (6)客房信息查询 图6 客房信息查询 private void Form2_Load(object sender, EventArgs e) try string ConStr = server=左-PC;User id=u3;p
22、wd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); string SqlStr = select 客房号,客房类型,楼层,价格 from 客房信息; SqlDataAdapter ada = new SqlDataAdapter(SqlStr, con); DataSet ds = new DataSet(); ada.Fill(ds); this.dataGridView1.DataSource = ds.Tables0.DefaultView; catch return; (7)前台管理员密码修改
23、图7 前台管理员密码修改private void 前台操作员管理_Load(object sender, EventArgs e) string ConStr = server=左-PC;User id=u3;pwd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); con.Open(); SqlCommand com = new SqlCommand(select 用户姓名 from 操作用户2, con); SqlDataReader dr = com.ExecuteReader(); comboBox
24、1.Items.Clear(); while (dr.Read() comboBox1.Items.Add(dr0.ToString(); dr.Close(); con.Close(); private void button1_Click(object sender, EventArgs e) string ConStr = server=左-PC;User id=u3;pwd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); using (SqlCommand cmd = new SqlCommand
25、() con.Open(); cmd.Connection = con; cmd.CommandType = CommandType.StoredProcedure; cmd.CommandText = 用户_update; SqlParameter par = new SqlParameter(name,boBox1 .Text), new SqlParameter(pwd,this .textBox2 .Text ), new SqlParameter(zw ,this .textBox3 .Text ) ; foreach (SqlParameter parms in par) cmd.
26、Parameters.Add(parms); cmd.ExecuteNonQuery(); con.Close(); MessageBox.Show(已经成功修改); private void button2_Click_1(object sender, EventArgs e) 显示修改后的数据库信息 m = new 显示修改后的数据库信息(); m.Show(); private void 显示修改后的数据库信息_Load(object sender, EventArgs e) string ConStr = server=左-PC;User id=u3;pwd=123;database=
27、酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); string SqlStr = select * from 操作用户2; SqlDataAdapter ada = new SqlDataAdapter(SqlStr, con); DataSet ds = new DataSet(); ada.Fill(ds); this.dataGridView1.DataSource = ds.Tables0.DefaultView; (8)前台管理员主界面图8 前台管理员主界面private void Form2_Load(object se
28、nder, EventArgs e) try string ConStr = server=左-PC;User id=u3;pwd=123;database=酒店客房数据库; SqlConnection con = new SqlConnection(ConStr); string SqlStr = select 客房号,客房类型,楼层,价格 from 客房信息; SqlDataAdapter ada = new SqlDataAdapter(SqlStr, con); DataSet ds = new DataSet(); ada.Fill(ds); this.dataGridView1.D
29、ataSource = ds.Tables0.DefaultView; catch return; (9)客房预订界面图9 客房预订界面 private void Form3_Load(object sender, EventArgs e) string ConStr1 = server=左-PC;User id=u3;pwd=123;database=酒店客房数据库; SqlConnection con1 = new SqlConnection(ConStr1); con1.Open(); SqlCommand com1 = new SqlCommand(select 客房号 from 客房
30、信息 where 客房号 not in (select 客房号 from 客人预订 where 客房状态 is not null), con1); SqlDataReader dr1 = com1.ExecuteReader(); comboBox1.Items.Clear(); while (dr1.Read() comboBox1.Items.Add(dr10.ToString(); dr1.Close(); con1.Close(); string ConStr3 = server=左-PC;User id=u3;pwd=123;database=酒店客房数据库; SqlConnecti
31、on con3 = new SqlConnection(ConStr3); con3.Open(); SqlCommand com3 = new SqlCommand(select distinct 预订方式 from 客房信息 , con3); SqlDataReader dr3 = com3.ExecuteReader(); comboBox3.Items.Clear(); while (dr3.Read() comboBox3.Items.Add(dr30.ToString(); dr3.Close(); con3.Close(); private void button1_Click(object sender, EventArgs e)