C#课程设计餐饮管理系统(DOC)上课讲义_第1页
C#课程设计餐饮管理系统(DOC)上课讲义_第2页
C#课程设计餐饮管理系统(DOC)上课讲义_第3页
C#课程设计餐饮管理系统(DOC)上课讲义_第4页
C#课程设计餐饮管理系统(DOC)上课讲义_第5页
已阅读5页,还剩28页未读 继续免费阅读

下载本文档

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

文档简介

1、郑州科技学院C#课程设计设计(论文)题目:餐饮管理系统所在院:信息工程学院专业班级:10计算机科学与技术2班学生姓名:简奇学号:201015048指导教师:王玉萍2013年1月8日 TOC o 1-5 h z HYPERLINK l bookmark4 o Current Document 第一部分 引言 2 HYPERLINK l bookmark6 o Current Document 课题意义 3 HYPERLINK l bookmark8 o Current Document 课题内容 4第二部分需求分析 4需求分析 5系统结构 5系统设计 5第三部分总体设计 6 HYPERLINK

2、l bookmark17 o Current Document 餐饮结构图 6基本业务图 7第四部分核心代码实现 7登录模块实现7 HYPERLINK l bookmark22 o Current Document 主框架实现 11 HYPERLINK l bookmark24 o Current Document 日历模块实现 20 HYPERLINK l bookmark26 o Current Document 4菜单模块22 HYPERLINK l bookmark30 o Current Document 第五部分结束语 29 HYPERLINK l bookmark32 o Cur

3、rent Document 1主要30 HYPERLINK l bookmark34 o Current Document 5.2进一步改进方向 31 HYPERLINK l bookmark36 o Current Document 第六部分参考文献31第一部分 引言课题意义近年来,随着人民的生活水平的不断提高,餐饮业的消费持续增长,竞争愈来愈激烈。然而,传统餐饮企业的日常运作还是靠人工管理,从原材料入库到客人点单,再到结账基本上由人工完成记录,这样做不仅耗费人力资源而且容易导致记录丢失或重复等错误,造成管理水平低下。酒店作为传统的餐饮企业也存在这些问题,进货,库存有人工管理,客人点单需服务

4、员记录并送至厨房,客人结账由手工记录,人力耗费大,客人等待时间长,管理效率低下,这就迫切需要标准的、 高效率的计算机管理方式引导其发展, 通过计算机管理该企业的日常运作,给管理者以决策参考的模型,来不断完善管理水平,提高工作效率。改革开放二十多年来,我国餐饮业发展迅猛,日新月异,各种风味特色,各种经营形式,各种组织结构的餐饮企业星罗棋布,但“竞争激烈, 生意难作”也成了餐饮业的“流行脖。 更新经营方式,拓展大众市场,建全餐饮业的“软硬”件设施,发展餐饮信息渠道是我国餐饮业应探索的主旋律。 所以, 社会化, 科学化, 集锦化 21 世纪的发展方向。当今世界已进入了在计算机信息管理领域中激烈竞争的

5、时代,应用计算机已经变得十分普遍了, 如同我们离不开的自行车、 汽车一样。我们应该承认,谁掌握的知识多,信息量大,信息处理速度快,批量大,谁的效率就高,谁就能够在各种竞争中立于不败之地。随着科学技术的不断提高 , 计算机科学日渐成熟, 其强大的功能已为人们深刻认识 , 它已进入人类社会的各个领域并发挥着越来越重要的作用。 越来越多的管理人员意识到信息管理的重要性。所以说科学化是二十一世纪餐饮业的主流目前, 国内的餐饮管理系统几种情况是: 中国的软件系统大多源自管理信息系统(MIS) , 从部门业务需求的角度出发设计。 管理信息系统设计的初衷是服务于学校内绝大多数的业务操作人员,将业务操作人员的

6、重复性劳动予以初场户动化,即从管理理论抽象出理想化的业务管理模式,在基于该业务模式的摹础上实现低层次的数据处理或业务流程电子化。管理信息系统的设计,是根据中小型学校业务单元的需求来编写的,一般无法满足多体制、多元化、多董组织结构的大型学校数据处理需求。与国外同类应用系统及解决方案相比较,目前中国的管理软件还有一些缺憾: 第一, 很多是从管理信息系统演变而来, 虽然目前国内的管理软件已将模块功能扩展至学校管理或人才资本管理相关的整个业务领域,但系统在整体性、前瞻性和集成性方面仍有欠缺。课题内容本课题是设计一个基于C# 勺餐饮管理系统。本系统属于小型的餐饮管理系统,可以有效地对中小型餐厅消费进行管

7、理,本系统应达到以下目标:系统采用人机交互的方式,界面美观友好,信息查询灵活、方便,数据存储安全可靠。实现对餐厅顾客开台、点菜/ 加菜、账目查询和结账等操作。对用户输入的数据,进行严格的数据检验,尽可能的避免人为错误。实现对消费账目自动结算。实现对消费的历史记录进行查询,支持模糊查询。系统应最大限度地实现易维护性和易操作性。第二部分 需求分析需求分析作为餐饮管理系统,首先需要具有餐饮管理员可以运用系统来进行登记的功能。在进行登记后,餐饮管理员就可以登录了,在登录以后可以对现有的信息的查看、修改等。由于餐饮管理系统是信息管理系统, 利用计算机网络的巨大潜在力量、数据信息的理念,从而减少人、物及财

8、等方面上的消耗,完成合理的资源分配。 其开发的功能主要包括: 本课题是设计一个基于 .NET的餐饮管理系统。确的餐饮管理依据与辅助决策数据。系统结构根据以上对餐饮管理系统的功能需求分析。现对餐饮管理系统分析。系统设计不管是管理员还是普通餐饮管理员登录系统都要进行正确的判断第三部分总体设计餐饮结构图餐饮管理系统系统恢复 系统备份 权限管理 记事本口令设置锁士 7E系 统退出系统3.2业务流程图基本登陆第四部分核心代码实现4. 1登录模块实现using System;using System.Collections.Generic;using System.ComponentModel;using

9、 System.Data;using System.Drawing;using System.Text;using System.Linq;using System.Windows.Forms;using System.Data.SqlClient;namespaceMrCypublic partial class frmLogin : Form public frmLogin()InitializeComponent(); private void Form1_Load( object sender, EventArgs e) txtName.Focus(); private void tx

10、tPwd_KeyPress( object sender, KeyPressEventArgs e) if (e.KeyChar = 13)btnSubmit_Click(sender, e); private void btnSubmit_Click( object sender, EventArgs e) if (txtName.Text = )MessageBox.Show(”请输入用户名,警告,MessageBoxButtons .OK, MessageBoxIcon .Warning);elseif (txtPwd.Text = )MessageBox.Show(请输入密码,警告 M

11、essageBoxButtons .OK, MessageBoxIcon .Warning);elseSqlConnection conn = BaseClass.DBConn .CyCon(); conn.Open();SqlCommand cmd = new SqlCommand (select * from tb_User where UserName= + txtName.Text + and UserPwd= + txtPwd.Text + , conn);SqlDataReader sdr = cmd.ExecuteReader();sdr.Read();if (sdr.HasRo

12、ws)sdr.Close();cmd = new SqlCommand (select * from tb_User whereUserName= + txtName.Text + , conn);SqlDataReader sdr1 = cmd.ExecuteReader();sdr1.Read();string UserPower = sdr1 power .ToString().Trim();conn.Close();frmMain main = new frmMain ();main.power = UserPower;main.Names = txtName.Text;main.Ti

13、mes = DateTime .Now.ToShortDateString();main.Show();this.Hide();elseMessageBox.Show(用户名或密码错误 工private void btnConcel_Click( object sender, EventArgs e)if (MessageBox.Show(确定退出系统吗?,提示, MessageBoxButtons .OKCancel, MessageBoxIcon .Asterisk) = DialogResult .OK)Application .Exit();登陆界面如图主框架实现using Syste

14、m;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Linq;using System.Windows.Forms;using System.Data.SqlClient;namespaceMrCypublic partial class frmMain : Formpublic frmMain()InitializeComponent();public SqlDataReader

15、sdr;public string power;public string Names;public string Times;private void frmMain_Load( object sender, EventArgs e)switch (power)break;case 0: toolStripStatusLabel13.Text = 超级管理员;case 1: toolStripStatusLabel13.Text = 经理; break;case 2: toolStripStatusLabel13.Text = 一般用户; break;toolStripStatusLabel

16、10.Text = Names;toolStripStatusLabel16.Text = Times;if (power = 2)系统维护SToolStripMenuItem.Enabled = false;基础信息MToolStripMenuItem.Enabled = false;if (power = 1)系统维护 SToolStripMenuItem.Enabled = false;private void AddItems( string rzt)if (rzt = 使用 )lvDesk.Items.Add(sdr RoomName .ToString(), 1); elselvD

17、esk.Items.Add(sdr RoomName .ToString(), 0);private void 开台 ToolStripMenuItem_Click( object sender, EventArgs e) if (lvDesk.SelectedItems.Count != 0)string names = lvDesk.SelectedItems0.SubItems0.Text;frmOpen openroom = new frmOpen (); = names;openroom.ShowDialog(); elseMessageBox.Show(请选择桌台工private

18、void frmMain_Activated( object sender, EventArgs e)lvDesk.Items.Clear();SqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();conn);SqlCommand cmd = new SqlCommand (select * from tb_Room ,sdr = cmd.ExecuteReader();while (sdr.Read()string zt = sdr RoomZT .ToString().Trim();AddItems(zt);conn.Clos

19、e();private void 点菜 ToolStripMenuItem_Click( object sender, EventArgs e) if (lvDesk.SelectedItems.Count != 0)string names = lvDesk.SelectedItems0.SubItems0.Text;frmDC dc = new frmDC ();dc.RName = names;dc.ShowDialog();elseMessageBox.Show(请选择桌台工private void 消费查询 ToolStripMenuItem_Click( object sender

20、, EventArgs e)if (lvDesk.SelectedItems.Count != 0)string names = lvDesk.SelectedItems0.SubItems0.Text;frmSerch serch = new frmSerch ();serch.RName = names;serch.ShowDialog();elseMessageBox.Show(请选择桌台工private void 结账 ToolStripMenuItem_Click( object sender, EventArgs e) if (lvDesk.SelectedItems.Count

21、!= 0) string names = lvDesk.SelectedItems0.SubItems0.Text;frmJZ jz = new frmJZ ();jz.Rname = names;jz.ShowDialog();elseMessageBox.Show(请选择桌台);private void lvDesk_DoubleClick( object sender, EventArgs e) frmDetails details = new frmDetails ();details.TableName = lvDesk.SelectedItems0.SubItems0.Text;d

22、etails.ShowDialog();private void lvDesk_Click( object sender, EventArgs e) string names = lvDesk.SelectedItems0.SubItems0.Text;SqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();SqlCommand cmd = new SqlCommand (select * from tb_Roomwhere RoomName= + names + , conn);SqlDataReader sdr = cmd.Ex

23、ecuteReader();sdr.Read();string zt = sdr RoomZT .ToString().Trim();sdr.Close();if (zt = 使用 )this.contextMenuStrip1.Items0.Enabled = false;this.contextMenuStrip1.Items1.Enabled = true; this.contextMenuStrip1.Items3.Enabled = true;this.contextMenuStrip1.Items5.Enabled = true;this.contextMenuStrip1.Ite

24、ms6.Enabled = true;if (zt = 待用 )this.contextMenuStrip1.Items0.Enabled = true;this.contextMenuStrip1.Items1.Enabled = false;this.contextMenuStrip1.Items3.Enabled = false;this.contextMenuStrip1.Items5.Enabled = false;this.contextMenuStrip1.Items6.Enabled = false;conn.Close();private void 取消开台 toolStri

25、pMenuItem_Click( object sender, EventArgs e)if (lvDesk.SelectedItems.Count != 0)string names = lvDesk.SelectedItems0.SubItems0.Text;SqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();SqlCommand cmd = new SqlCommand(update tb_Room setRoomZT= 待用 ,Num=0 where RoomName= + names + , conn);cmd.Exe

26、cuteNonQuery();cmd = new SqlCommand (delete from tb_GuestFood where zhuotai= + names + , conn);cmd.ExecuteNonQuery();conn.Close();frmMain_Activated(sender, e);elseMessageBox.Show(请选择桌台工private void 桌台信息 ToolStripMenuItem1_Click( object sender, EventArgs e)frmDesk desk = new frmDesk ();desk.ShowDialo

27、g();private void 职员信息 ToolStripMenuItem1_Click( object sender, EventArgs e)frmUser users = new frmUser();users.ShowDialog();private void 日历 ToolStripMenuItem1_Click( object sender, EventArgs e) frmCalender calender = new frmCalender ();calender.ShowDialog();private void 记事本 ToolStripMenuItem1_Click(

28、 object sender, EventArgs e)System.Diagnostics.Process.Start(notepad.exe );private void 计算器 ToolStripMenuItem1_Click( object sender, EventArgs e)System.Diagnostics.Process.Start(calc.exe ); private void 权限管理 ToolStripMenuItem1_Click( object sender,EventArgs e)frmQxGl qx = new frmQxGl ();qx.ShowDialo

29、g();private void 系统备份 ToolStripMenuItem1_Click( object sender, EventArgs e)frmBF bf = new frmBF ();bf.ShowDialog();private void 系统恢复 ToolStripMenuItem1_Click( object sender, EventArgs e)sdr.Close();sdr.Dispose();frmHF hf = new frmHF ();hf.ShowDialog();private void 口令设置 ToolStripMenuItem1_Click( obje

30、ct sender, EventArgs e)frmPwd pwd = new frmPwd ();s = Names;pwd.ShowDialog();private void 锁定系统 ToolStripMenuItem1_Click( object sender, EventArgs e)frmLock locksystem = new frmLock ();locksystem.Owner = this;locksystem.ShowDialog();private void 关于 ToolStripMenuItem1_Click( object sender, EventArgs e

31、) AboutBox1 ab = new AboutBox1 ();ab.ShowDialog();private void 退出系统 ToolStripMenuItem1_Click( object sender, EventArgs e)if (MessageBox.Show( 确定退出本系统吗? , 提示 , MessageBoxButtons .OKCancel, MessageBoxIcon .Exclamation) = DialogResult .OK)Application .Exit(); private void 系统维护 SToolStripMenuItem_Click(

32、 object sender, EventArgs e)private void lvDesk_SelectedIndexChanged( object sender, EventArgs e) private void contextMenuStrip1_Opening( object sender, CancelEventArgse)private void contextMenuStrip1_Opened( object sender, EventArgs e) 主框架运行实现史上信mMsfc_=拿笠=匡小城jEui注肥以 三二鼻附匕力心为431零rssSEpl与SmaguLhTl cc

33、ffretftMtfiijStripl日历模块using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Linq;using System.Windows.Forms;namespaceMrCypublic partial class frmCalender : Formpublic frmCalender()InitializeComponent();private

34、 void frmCalender_Load( object sender, EventArgs e) 运行界面如下图日日历百| mu IM jiiBMUBiiiaaii iimjiii bu* am mm m am . &a. a sbi - ssin .42。1隼月周日周二周三周四周五周六建272S2930311234567&510111212141516171S192021222324252627282?301234564.4 菜单模块using System;using System.Collections.Generic;using System.ComponentModel;usi

35、ng System.Data;using System.Drawing;using System.Text;using System.Linq;using System.Windows.Forms;using System.Data.SqlClient;namespaceMrCypublic partial class frmDC : Form public frmDC()InitializeComponent();public string RName;private void frmDC_Load( object sender, EventArgs e)this.Text = RName

36、+ 点/加菜 ;TreeNode newnode1 = tvFood.Nodes.Add( 锅底 );TreeNode newnode2 = tvFood.Nodes.Add( 配菜 );TreeNode newnode3 = tvFood.Nodes.Add( 烟酒 );TreeNode newnode4 = tvFood.Nodes.Add( 主食 );SqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();SqlCommand cmd = new SqlCommand (select * from tb_food wheref

37、oodty=1 , conn);SqlDataReader sdr = cmd.ExecuteReader(); while (sdr.Read()newnode1.Nodes.Add(sdr3.ToString().Trim();sdr.Close();cmd = new SqlCommand(select * from tb_food where foodty=2conn);sdr = cmd.ExecuteReader();while (sdr.Read()newnode2.Nodes.Add(sdr3.ToString().Trim();sdr.Close();cmd = new Sq

38、lCommand(select * from tb_food where foodty=3conn);sdr = cmd.ExecuteReader();while (sdr.Read()newnode3.Nodes.Add(sdr3.ToString().Trim();sdr.Close();cmd = new SqlCommand(select * from tb_food where foodty=4conn);sdr = cmd.ExecuteReader();while (sdr.Read()newnode4.Nodes.Add(sdr3.ToString().Trim();sdr.

39、Close();cmd = new SqlCommand(select * from tb_Waiter ,conn);sdr = cmd.ExecuteReader();while (sdr.Read()cbWaiter.Items.Add(sdr WaiterName .ToString().Trim();cbWaiter.SelectedIndex = 0;sdr.Close();cmd = new SqlCommand(select RoomZT from tb_Room where RoomName= +RName+ ,conn);string zt = Convert.ToStri

40、ng(cmd.ExecuteScalar();if (zt.Trim() = 待用 )groupBox1.Enabled = false;groupBox2.Enabled = false;groupBox3.Enabled = false;groupBox4.Enabled = false;conn.Close();GetData();tvFood.ExpandAll();private void treeView1_DoubleClick( object sender, EventArgs e)string foodname = tvFood.SelectedNode.Text;if (f

41、oodname = 锅底 | foodname = 配菜 | foodname = 烟酒 | foodname = 主食 )elseSqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();SqlCommand cmd = new SqlCommand (select * from tb_food where foodname= + foodname + , conn);SqlDataReader sdr = cmd.ExecuteReader();sdr.Read();txtNum.Text = sdr foodnum .ToStr

42、ing().Trim();txtName.Text = foodname;txtprice.Text = sdr foodprice .ToString().Trim();conn.Close();if (txtpnum.Text = )MessageBox.Show(数量不能为空);return; else txtallprice.Text =Convert.ToString( Convert .ToInt32(txtprice.Text) * Convert.ToInt32(txtpnum.Text); private void txtpnum_TextChanged( object se

43、nder, EventArgs e)if (txtpnum.Text = )MessageBox.Show(数量不能为空);return; else if (Convert .ToInt32(txtpnum.Text) 0)/string names = dgvFoods.SelectedCells0.Value.ToString(); int intID =Convert.ToInt32(dgvFoods.CurrentRow.Cells7.Value);SqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();/SqlComman

44、d cmd = new SqlCommand(delete from tb_GuestFood where foodname= + names + and zhuotai= + RName + , conn);SqlCommand cmd = new SqlCommand (delete from tb_GuestFood where ID = + intID + , conn);cmd.ExecuteNonQuery();conn.Close();GetData();private void btnSave_Click( object sender, EventArgs e) if (txt

45、Name.Text = | txtNum.Text = | txtprice.Text = ) MessageBox.Show(请将选择菜系工 return; else if (txtpnum.Text = )MessageBox.Show(数量不能为空); return; else if (Convert.ToInt32(txtpnum.Text) = 0) MessageBox.Show(请输入消费数量工 return; elseSqlConnection conn = BaseClass.DBConn .CyCon();conn.Open();SqlCommand cmd = new S

46、qlCommand(insert into tb_GuestFood(foodnum,foodname,foodsum,foodallprice,waitername,beizhu,zhuotai, datatime) values( + txtNum.Text.Trim() + , + txtName.Text.Trim() + , + txtpnum.Text.Trim() + , + Convert .ToDecimal(txtallprice.Text.Trim() +, +cbWaiter.SelectedItem.ToString() + , + txtbz.Text.Trim()

47、 + , + RName + , +DateTime.Now.ToString() + ) , conn);cmd.ExecuteNonQuery();conn.Close();GetData();private void btnExit_Click( object sender, EventArgs e)this.Close();private void groupBox2_Enter( object sender,EventArgs e) 运行结果口 TI 次 I菜品类别菜单编号:蕖品名称士第五部分结束语经过这次开发基C#勺餐饮管理系统系统的设计与实现的设计,使 我对C#t较深的认识及体会

48、。在本开发系统时,由于是本人初次接触 有关C猴域;在知识、经验方面都存在着太多的不足。另外,在开发 的整个过程中,时间也较仓促。因此,该系统必然会存在很多不足。 因为对整个学校的管理模式不够了解及对整个系统的流程不够熟悉, 在需求分析阶段用户的需求未能做到完全满足,如系统还没做到请假 信息的管理,不能从考核信息中得出考核工资等等。在系统功能上, 还有部分问题是我还没有考虑到的,所以本系统还有继续开发一定空不过,我觉得学习一种新的技术能学习到运用此技术开发出一个有意义的系统是不容易的,这同时也使我增强对知识的渴望和追求的欲望。在整个软件的设计开发过程中真实感受到设计开发的长期和艰辛,同时也获得设

49、计开发的经验和感受,首先就是始终要有对项目开发的兴趣、 爱好、 激情和积极追求的思维; 其次必须要有广博的知识、文献和技术书籍,可供搜索,能去查阅,联络访问;再次要有迎难而上的决心和恒心, 面对疑难要静心和细心, 也要有一定的耐心和信心,才能把握关键;最后要有一定的时限,要有足够的时间去针对每个细节,逐个排查问题,应付设计开发各种过程的考验;此外,一个大的项目的开发设计的确要有协助合作伙伴,多与人讨论,虽然设计是一人独立完成,但多与人交流经验,能增强团队合作意思,适应将来的需要。这里整个软件设计及近尾声,最大的收获就是深化了对项目的设计开发、结构框架和C#g程语言的学习,从基础的语法代码,上升 到

温馨提示

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

评论

0/150

提交评论