小型餐飲系統(tǒng)課程設計_第1頁
已閱讀1頁,還剩26頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  《數(shù)據庫原理及應用》</p><p><b>  課程設計報告</b></p><p> 題目:小型酒店數(shù)據庫設計 </p><p><b>  目錄</b></p><p><b>  一、需求分析3</b></p><p

2、><b>  二、概要設計3</b></p><p><b>  三、邏輯設計5</b></p><p>  四、建立數(shù)據庫10</p><p>  1、數(shù)據庫及數(shù)據庫對象建立10</p><p>  2、數(shù)據庫測試13</p><p><b>  

3、五、總結25</b></p><p><b>  六、參考文獻26</b></p><p><b>  一、需求分析</b></p><p>  根據餐飲行業(yè)的特點和實際情況,酒店管理系統(tǒng)應以餐飲業(yè)務為基礎,突出前臺管理,重視營業(yè)數(shù)據分析等功能,從專業(yè)角度出發(fā),努力為餐飲管理者提供科學有效地管理模式和數(shù)據分

4、析功能。</p><p>  在餐飲店中,當顧客進來時需要根據顧客人數(shù)安排餐桌,確定餐桌后,為其安排點菜,得到顧客菜單后送交廚房并讓其烹飪相應的菜式,在用餐期間顧客可變更菜單,而廚房就需要及時核對顧客菜單,以做出改變。最后對顧客菜單進行結算,得到賬單送給顧客結賬,并將發(fā)票送至顧客和財務部門處。另外,對于操作用戶有一定的管理,并對用戶權限有一定的設置。</p><p><b>  

5、二、概要設計</b></p><p>  圖3.1用戶E-R圖</p><p>  主要存儲一些用戶信息,如用戶的賬號、密碼和類型地點等等,主要用于用戶登錄,添加客戶和添加預定時會使用到用戶信息。</p><p>  圖3.2客戶E-R圖</p><p>  主要存儲一些客戶信息,如客戶的賬號、密碼、聯(lián)系方式和消費情況等等,主要用

6、于客戶訂餐、充值和結算,使用于添加預定。</p><p>  圖3.3食譜E-R圖</p><p>  主要存儲一些食譜信息,如食譜的名稱、價格和照片等等,主要用于客戶訂餐,使用于添加預定。</p><p>  圖3.4 預定E-R圖</p><p>  主要存儲一些預定信息,如客戶的賬號、預定的時間、桌號和菜單等等,主要用于記錄客戶的預定信

7、息,會使用到用戶、客戶、菜單和折扣信息。</p><p>  圖3.5 折扣E-R圖</p><p>  存儲管理員(店主)設定的打折信息,用來計算打折后的應付金額,使用在添加預定時打折。</p><p>  圖3.6 總E-R圖</p><p><b>  三、邏輯設計</b></p><p>

8、  1、User(用戶表)</p><p>  表3.1 user</p><p>  用戶表主要用于存儲一些用戶信息,如用戶的賬號、密碼和類型地點等等,主要用于用戶登錄,添加客戶和添加預定時會使用到用戶信息來記錄經手的用戶,字段money用于記錄用戶的收款金額,便于結算時對收款現(xiàn)金的核對。</p><p>  2、customer(客戶表)</p>

9、<p>  表3.2 customer</p><p>  客戶表主要用于存儲一些客戶信息,如客戶的賬號、密碼、聯(lián)系方式和消費情況等等,主要用于客戶訂餐、充值和結算,字段money用于儲存賬戶余額,在使用充值和賬戶余額支付時會使用到它。字段usedmoney用于記錄客戶的消費情況,為客戶打折時會使用到它。</p><p>  3、food (食譜表)</p>&

10、lt;p>  表3.3 food</p><p>  食譜表主要用于存儲一些食譜信息,如食譜的名稱、價格和照片等等,主要用于客戶訂餐,使用于添加預定。字段Price記錄的是食物的價格。當客戶預定餐點時,系統(tǒng)使用它來算費用。</p><p>  4、YuDing(預定表)</p><p>  表3.4 YuDing</p><p> 

11、 預定表主要用于存儲一些預定信息,如客戶的賬號、預定的時間、桌號和菜單等等,主要用于記錄客戶的預定信息,會使用到用戶、客戶、菜單和折扣信息。當系統(tǒng)預定餐點時,會從其他各表中調出需要的信息,經過計算和處理后,將最終信息儲存到YuDing表,該表和其它各表都有緊密的聯(lián)系。</p><p>  5、discount(折扣表)</p><p>  表3.5 discount表</p>

12、<p>  折扣表用于存儲管理員(店主)設定的打折信息,用來計算打折后的應付金額,使用在添加預定時打折。當客戶預定餐點時,打折服務的折扣程度就是參照該表。</p><p><b>  四、建立數(shù)據庫</b></p><p>  1、數(shù)據庫及數(shù)據庫對象建立</p><p>  create database Restaurant_Ma

13、nagement</p><p>  --drop table Dish</p><p>  create table Dish --菜譜</p><p>  (Dishno varchar(10)primary key,</p><p>  Dishname varchar(10),</p><p>  Dishcl

14、ass varchar(10),</p><p>  Dishprice float ,</p><p>  Dishstate varchar(6) check(Dishstate = '有' or Dishstate = '無'),</p><p><b>  )</b></p><p&g

15、t;  --drop table Oder</p><p>  create table Oder--訂單</p><p>  (Oderno varchar(10) primary key,</p><p>  Customerno varchar(10) not null,</p><p>  Odertime datetime not

16、null,</p><p>  Foodtableno varchar(10) not null,</p><p>  foreign key (Customerno) references Customer(Customerno),</p><p>  foreign key (Foodtableno) references Foodtable(Foodtable

17、no)</p><p><b>  )</b></p><p>  --drop table Foodtable</p><p>  create table Foodtable--桌臺信息</p><p>  (Foodtableno varchar(10)primary key,</p><p&g

18、t;  seatingno int not null,</p><p>  Foodtablestate varchar(6) check(Foodtablestate = '空' or Foodtablestate = '占')</p><p><b>  )</b></p><p>  --drop tabl

19、e Menus</p><p>  create table Menus --菜單</p><p>  (Menuno varchar(10)primary key,</p><p>  Foodtableno varchar(10) not null,</p><p>  Customerno varchar(10)not null,<

20、;/p><p>  Oderno varchar(10),</p><p>  Workerno varchar(10)not null,</p><p>  consumetime datetime,</p><p>  foreign key(Foodtableno) references Foodtable(Foodtableno),<

21、;/p><p>  foreign key(Customerno) references Customer(Customerno),</p><p><b>  )</b></p><p>  --drop table Menus_Dish</p><p>  create table Menus_Dish --菜單_菜品&

22、lt;/p><p>  (Menuno varchar(10) ,</p><p>  Dishno varchar(10) ,</p><p>  Dishname varchar(20) not null,</p><p>  Amount int not null,</p><p>  primary key(Men

23、uno,Dishno),</p><p>  foreign key (Dishno) references Dish(Dishno)</p><p><b>  )</b></p><p>  alter table Menus_Dish add check(Amount>0)</p><p>  --drop

24、table Customer</p><p>  create table Customer --顧客</p><p>  (Customerno varchar(10) primary key,</p><p>  Customername varchar(10) not null,</p><p>  Customersex varcha

25、r(4) check(Customersex = '男' or Customersex = '女')not null,</p><p>  Custoemrphoneno varchar(20) unique not null,</p><p>  VIP_level int,</p><p>  totalexpend float&

26、lt;/p><p><b>  )</b></p><p>  alter table customer alter column totalexpend float(5)</p><p>  --drop table Discount_rules</p><p>  create table Discount_rules-

27、-折扣規(guī)則</p><p>  (VIP_level int primary key,</p><p>  Discount float,</p><p><b>  )</b></p><p>  --drop table worker</p><p>  create table worker

28、--員工</p><p>  (Workerno varchar(10) primary key,</p><p>  Workername varchar(10),</p><p>  Workersex varchar(4) check(Workersex = '男' or Workersex = '女'),</p>

29、<p>  Workerage int,</p><p>  Workersalary int,</p><p><b>  )</b></p><p>  --drop table Sales_bill</p><p>  create table Sales_bill--銷售賬</p>&l

30、t;p>  (Menuno varchar(10),</p><p>  Saleroom float(5),</p><p>  Billtime datetime</p><p><b>  )</b></p><p><b>  2、數(shù)據庫測試</b></p><p&

31、gt;  對建立的數(shù)據庫及數(shù)據庫對象進行測試</p><p>  (1)、存儲過程測試</p><p><b>  插入新顧客信息</b></p><p>  --drop proc 插入新顧客信息</p><p>  create proc 插入新顧客信息</p><p>  @Customer

32、no varchar(10), @Customername varchar(10), </p><p>  @Customersex varchar(4), @Custoemrphoneno varchar(20)</p><p><b>  as</b></p><p>  Insert into customer values(@Cust

33、omerno, @Customername, @Customersex, @Custoemrphoneno, 0, 0)</p><p><b>  測驗</b></p><p>  exec 插入新顧客信息 'C_035','楊濤','男','18700809052'</p><p&

34、gt;<b>  預定</b></p><p>  --drop proc 預定</p><p>  create procedure 預定</p><p>  @oderno varchar(10),</p><p>  @Customerno varchar(10),</p><p>  @o

35、dertime datetime,</p><p>  @Foodtableno varchar(10)</p><p><b>  as </b></p><p>  insert into Oder values(@oderno,@Customerno,@odertime,@Foodtableno)</p><p>

36、;  exec 預定 'O_005','C_035','2012-6-16','TB_8'</p><p><b>  查詢預定</b></p><p>  --drop proc 查詢預訂</p><p>  create proc 查詢預訂</p><p&g

37、t;  @Customerno varchar(10),</p><p>  @Oderno varchar(10) output</p><p><b>  as </b></p><p>  if exists(select* from oder where customerno=@Customerno)</p><p

38、><b>  begin</b></p><p>  print '已預訂'</p><p>  select @Oderno=oderno</p><p>  from oder where customerno=@Customerno</p><p>  print '預定號為:'

39、;+@Oderno</p><p><b>  end</b></p><p>  else print '未預定'</p><p>  declare @Oderno varchar(10)</p><p>  exec 查詢預訂 'C_002', @Oderno output</

40、p><p>  declare @Oderno varchar(10)</p><p>  exec 查詢預訂 'C_035', @Oderno output</p><p><b>  開臺信息</b></p><p>  --drop proc 開臺</p><p>  creat

41、e proc 開臺</p><p>  @Menuno varchar(10),@Foodtableno varchar(10),@customerno varchar(10),</p><p>  @Oderno varchar(10),@workerno varchar(10),@Customertime datetime</p><p><b>  

42、as </b></p><p>  insert into Menus</p><p>  values(@Menuno,@Foodtableno,@customerno,@Oderno,@workerno,@Customertime)</p><p>  update Foodtable set Foodtablestate='占' w

43、here Foodtableno = @Foodtableno</p><p>  exec 開臺 'M_010','TB_8','C_035','O_005','W_002','2012-6-11'</p><p><b>  插入菜單</b></p>&l

44、t;p><b>  修改桌臺狀態(tài)</b></p><p><b>  顧客點餐</b></p><p>  --drop proc 點菜</p><p>  create proc 點菜</p><p>  @Menuno varchar(10) ,@Dishno varchar(20),@D

45、ishname varchar(10) ,@Amount int </p><p><b>  as </b></p><p>  insert into menus_dish values(@Menuno,@Dishno,@Dishname,@Amount)</p><p><b>  點菜</b></p>

46、<p>  exec 點菜 'M_010','D-10','蒜泥黃瓜',2</p><p>  exec 點菜 'M_010','D-23','麻婆豆腐',1</p><p>  exec 點菜 'M_010','D-11','西芹杏仁'

47、;,1</p><p>  exec 點菜 'M_010','D-39','樟茶鴨子',1</p><p>  exec 點菜 'M_010','D-57','小炒臘肉',2</p><p>  exec 點菜 'M_010','D-72'

48、,'小炒河蝦',1</p><p><b>  計算總消費額</b></p><p>  --drop proc 消費總額</p><p>  create proc 消費總額</p><p>  @customerno varchar(10),</p><p>  @Salero

49、om float output</p><p><b>  as </b></p><p>  select @Saleroom=SUM(Dishprice*Amount)</p><p>  from menus_dish,Dish,Menus</p><p>  where Customerno=@customern

50、o </p><p>  and Menus.Menuno=Menus_Dish.Menuno</p><p>  and Dish.Dishno=menus_dish.Dishn </p><p><b>  測驗</b></p><p>  declare @Saleroom float, @customerno v

51、archar(10) = 'c_035'--出入顧客的編號,計算本次消費信息 </p><p>  exec 消費總額 @customerno , @Saleroom output</p><p>  select Customername, @Saleroom 總費用</p><p>  from Customer</p><

52、;p>  where Customerno = @customern</p><p><b>  查詢客戶點菜信息</b></p><p>  --drop proc 查詢客戶點菜</p><p>  create proc 查詢客戶點菜</p><p>  @customerno varchar(10)</

53、p><p><b>  as </b></p><p>  select Dish.Dishname ,Amount</p><p>  from Dish,menus_dish,menus</p><p>  where menus.Customerno=@customerno</p><p>  

54、and menus_dish.Menuno=menus.Menuno</p><p>  and Dish.Dishno=menus_dish.Dishno</p><p><b>  測驗</b></p><p>  exec 查詢客戶點菜 'c_035'</p><p>  exec 查詢客戶點菜

55、'c_001'</p><p><b>  菜品的刪除</b></p><p>  --drop proc 修改菜單</p><p>  create proc 修改菜單</p><p>  @Menuno varchar(10), @Dishname varchar(20)</p><

56、;p><b>  as </b></p><p><b>  delete </b></p><p>  from menus_dish</p><p>  where Menuno=@Menuno</p><p>  and Dishname= @Dishname</p>&l

57、t;p><b>  測驗</b></p><p>  exec 修改菜單 'M_010','小炒臘肉' </p><p><b>  發(fā)票信息</b></p><p>  --drop proc 發(fā)票信息</p><p>  create proc 發(fā)票信息

58、</p><p>  @customerno varchar(10),</p><p>  @Actuallypay1 float,</p><p>  @Menuno varchar(10) output,</p><p>  @Actuallypay2 float output,</p><p>  @custom

59、ername varchar(10) output,</p><p>  @Saleroom float output,</p><p>  @after_discount float output,</p><p>  @Billtime datetime output</p><p><b>  as </b><

60、;/p><p>  select @Saleroom=SUM(Dishprice*Amount)---本次消費總額</p><p>  from menus_dish,Dish,Menus</p><p>  where Customerno=@customerno </p><p>  and Menus.Menuno=Menus_Dish.M

61、enuno</p><p>  and Dish.Dishno=menus_dish.Dishno </p><p>  select @customername=customername ----查詢用戶姓名</p><p>  from customer </p><p>  where customerno = @customerno&

62、lt;/p><p>  select @Menuno=Menuno --獲取賬單號</p><p>  from Menus </p><p>  where Customerno=@customerno </p><p>  set @Billtime=getdate() ----獲取消費賬單時間</p><p>  

63、set @Actuallypay2=@Actuallypay1---獲取實付現(xiàn)金</p><p>  select @after_discount=@Saleroom*0.1*Discount ---計算折扣后費用</p><p>  from customer , Discount_rules </p><p>  where customer.VIP_level

64、=Discount_rules.VIP_level</p><p>  print '用戶名: ' +' '+ @customername--------打印發(fā)票</p><p>  print '實 付:' + str(@Actuallypay2, 10, 2)</p><p>  print '應 付:

65、' + str(@Saleroom, 10, 2)</p><p>  print '折扣后:' + str(@after_discount, 10, 2)</p><p>  print '應 找:' + str(@Actuallypay2-@after_discount, 10, 2)</p><p>  print &#

66、39;時 間:' +' '+ cast( @Billtime as varchar(20))</p><p>  update customer --修改顧客歷史消費總額</p><p>  set totalexpend = (totalexpend+@after_discount) </p><p>  where customerno

67、 = @customerno</p><p>  delete --刪除本次所點的所有的菜</p><p>  from menus_dish </p><p>  where Menuno =</p><p>  (select Menuno </p><p>  from Menus </p><

68、;p>  where customerno = @customerno)</p><p>  update Foodtable ---修改桌臺狀態(tài)</p><p>  set Foodtablestate='空' </p><p>  where Foodtableno = </p><p>  (select Food

69、tableno </p><p>  from Menus </p><p>  where customerno = @customerno)</p><p>  delete ---刪除菜單信息</p><p>  from Menus</p><p>  where customerno = @customern

70、o</p><p>  insert into sales_bill values(@Menuno,@after_discount,@Billtime)--插入消費信息到銷售賬單</p><p><b>  測驗</b></p><p><b>  declare </b></p><p>  @c

71、ustomername varchar(10) ,</p><p>  @Actuallypay2 float,</p><p>  @Saleroom float, </p><p>  @Menuno varchar(10), </p><p>  @after_discount float ,</p><p> 

72、 @Billtime datetime </p><p>  exec 發(fā)票信息 'c_002', 200,</p><p>  @customername output, </p><p>  @Actuallypay2 output,</p><p>  @Saleroom output,</p><

73、;p>  @Menuno output,</p><p>  @after_discount output,</p><p>  @Billtime output </p><p><b>  輸出發(fā)票信息</b></p><p><b>  修改桌臺信息</b></p><

74、;p><b>  插入消費賬單</b></p><p>  查詢某一時間段的營業(yè)額</p><p>  --drop proc 查詢營業(yè)額</p><p>  create proc 查詢營業(yè)額</p><p>  @begintime datetime,</p><p>  @endtim

75、e datetime,</p><p>  @sum_of_turnover float(5) output</p><p><b>  As</b></p><p>  select @sum_of_turnover=sum(Saleroom)</p><p>  from Sales_bill</p>

76、<p>  where Billtime>=@begintime and Billtime<@endtime</p><p>  print '從時間:'+ cast( @begintime as varchar(20))+' 到時間:'+ cast( @endtime as varchar(20))+</p><p>  

77、9; 的營業(yè)總額為:'+str(@sum_of_turnover, 10, 2)</p><p><b>  測驗</b></p><p>  declare @sum_of_turnover float(5)</p><p>  exec 查詢營業(yè)額 '2011-9-13' ,'2012-9-16',

78、@sum_of_turnover output</p><p>  select @sum_of_turnover </p><p><b>  觸發(fā)器</b></p><p><b>  VIP升級</b></p><p>  drop trigger trig_Upgrade_of_VIP_le

79、vel</p><p>  create trigger trig_Upgrade_of_VIP_level on Customer</p><p>  after update </p><p><b>  as</b></p><p>  declare @no varchar(20),</p><

80、;p>  @expend float,</p><p>  @level int </p><p>  select @no = Customerno, @expend=totalexpend, @level = VIP_level</p><p>  from inserted</p><p>  if(@expend < 5

81、00)</p><p>  set @level = 0</p><p>  else if(@expend >= 500 and @expend < 1000)</p><p>  set @level = 1</p><p>  else if(@expend >= 1000 and @expend < 1800)

82、</p><p>  set @level = 2</p><p>  else if(@expend >= 1800 and @expend < 2500)</p><p>  set @level = 3</p><p>  else if(@expend >= 2500 and @expend < 3500)&l

83、t;/p><p>  set @level = 4</p><p><b>  else</b></p><p>  set @level = 5</p><p>  update Customer set VIP_level = @level where Customerno = @no</p><p&

84、gt;  update Customer </p><p>  set totalexpend = 1200</p><p>  where Customerno = 'c_035'</p><p><b>  五、總結&l

85、t;/b></p><p>  終于完成了這份課程設計,心終于可以歇歇了。當再次回頭看看這份課程設計時,感慨萬千。這是一個充實自己的過程,每一天做的事兒就是做課程設計,翻閱相關書籍,網上百度,起初根本不知道怎么會事兒,后來才知道設計數(shù)據庫真是一個相當復雜的過程。老師一開始告訴我們要提前做,我們還感覺時間挺長,可是后來才知道老師是對的,時間真的過的很快,而我們還毫無進展,那時真是一個著急。慢慢的靜下心來,慢慢

86、摸索,才逐漸有了思路。我經常和同學一起探討問題,一起解決問題,在這當中我們學到了很多課本上沒有的知識。我不斷找錯,改錯,不斷改進,最終改進到這樣的地步。最后,很感激學校給了我們這次動手實踐的機會,讓我們學生有了一個共同學習,增長見識,開拓視野的機會。也感謝老師們對我們無私忘我的指導,我會以這次課程設計作為對自己的激勵,繼續(xù)學習。</p><p><b>  六、參考文獻 </b>&

87、lt;/p><p>  1.馬曉梅《SQL Server 2000》清華大學出版社</p><p>  2.吳豪《SQL Server 2000 基礎》北京希望電子出版社</p><p>  3.余金山《SQL Server 2000編程指南》北京希望電子出版社</p><p>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論