Chuyển bàn trong phần mềm Quản lý quán cafe với C# Winform
Lập trình phần mềm Quản lý quán cafe với C# Winform

Danh sách bài học
Chuyển bàn trong phần mềm Quản lý quán cafe với C# Winform
Không có gì tuyệt vời hơn là luyện tập với ví dụ thực tế. Nào cùng nhau thử thách bản thân với phần mềm: Quản lý quán cafe
Bạn nên có kiến thức về:
- Lập trình Winform cơ bản
- Delegate – Event
- SQL server
- Xử lý ngày tháng năm
Code fTableManager.cs
using QuanLyQuanCafe.DAO;
using QuanLyQuanCafe.DTO;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Globalization;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace QuanLyQuanCafe
{
public partial class fTableManager : Form
{
public fTableManager()
{
InitializeComponent();
LoadTable();
LoadCategory();
LoadComboboxTable(cbSwitchTable);
}
#region Method
void LoadCategory()
{
List<Category> listCategory = CategoryDAO.Instance.GetListCategory();
cbCategory.DataSource = listCategory;
cbCategory.DisplayMember = "Name";
}
void LoadFoodListByCategoryID(int id)
{
List<Food> listFood = FoodDAO.Instance.GetFoodByCategoryID(id);
cbFood.DataSource = listFood;
cbFood.DisplayMember = "Name";
}
void LoadTable()
{
flpTable.Controls.Clear();
List<Table> tableList = TableDAO.Instance.LoadTableList();
foreach (Table item in tableList)
{
Button btn = new Button() { Width = TableDAO.TableWidth, Height = TableDAO.TableHeight};
btn.Text = item.Name + Environment.NewLine + item.Status;
btn.Click += btn_Click;
btn.Tag = item;
switch (item.Status)
{
case "Trống":
btn.BackColor = Color.Aqua;
break;
default:
btn.BackColor = Color.LightPink;
break;
}
flpTable.Controls.Add(btn);
}
}
void ShowBill(int id)
{
lsvBill.Items.Clear();
List<QuanLyQuanCafe.DTO.Menu> listBillInfo = MenuDAO.Instance.GetListMenuByTable(id);
float totalPrice = 0;
foreach (QuanLyQuanCafe.DTO.Menu item in listBillInfo)
{
ListViewItem lsvItem = new ListViewItem(item.FoodName.ToString());
lsvItem.SubItems.Add(item.Count.ToString());
lsvItem.SubItems.Add(item.Price.ToString());
lsvItem.SubItems.Add(item.TotalPrice.ToString());
totalPrice += item.TotalPrice;
lsvBill.Items.Add(lsvItem);
}
CultureInfo culture = new CultureInfo("vi-VN");
//Thread.CurrentThread.CurrentCulture = culture;
txbTotalPrice.Text = totalPrice.ToString("c", culture);
}
void LoadComboboxTable(ComboBox cb)
{
cb.DataSource = TableDAO.Instance.LoadTableList();
cb.DisplayMember = "Name";
}
#endregion
#region Events
void btn_Click(object sender, EventArgs e)
{
int tableID = ((sender as Button).Tag as Table).ID;
lsvBill.Tag = (sender as Button).Tag;
ShowBill(tableID);
}
private void đăngXuấtToolStripMenuItem_Click(object sender, EventArgs e)
{
this.Close();
}
private void thôngTinCáNhânToolStripMenuItem_Click(object sender, EventArgs e)
{
fAccountProfile f = new fAccountProfile();
f.ShowDialog();
}
private void adminToolStripMenuItem_Click(object sender, EventArgs e)
{
fAdmin f = new fAdmin();
f.ShowDialog();
}
private void cbCategory_SelectedIndexChanged(object sender, EventArgs e)
{
int id = 0;
ComboBox cb = sender as ComboBox;
if (cb.SelectedItem == null)
return;
Category selected = cb.SelectedItem as Category;
id = selected.ID;
LoadFoodListByCategoryID(id);
}
private void btnAddFood_Click(object sender, EventArgs e)
{
Table table = lsvBill.Tag as Table;
int idBill = BillDAO.Instance.GetUncheckBillIDByTableID(table.ID);
int foodID = (cbFood.SelectedItem as Food).ID;
int count = (int)nmFoodCount.Value;
if (idBill == -1)
{
BillDAO.Instance.InsertBill(table.ID);
BillInfoDAO.Instance.InsertBillInfo(BillDAO.Instance.GetMaxIDBill(), foodID , count);
}
else
{
BillInfoDAO.Instance.InsertBillInfo(idBill, foodID, count);
}
ShowBill(table.ID);
LoadTable();
}
private void btnCheckOut_Click(object sender, EventArgs e)
{
Table table = lsvBill.Tag as Table;
int idBill = BillDAO.Instance.GetUncheckBillIDByTableID(table.ID);
int discount = (int)nmDisCount.Value;
double totalPrice = Convert.ToDouble(txbTotalPrice.Text.Split(',')[0]);
double finalTotalPrice = totalPrice - (totalPrice/100)*discount;
if (idBill != -1)
{
if (MessageBox.Show(string.Format("Bạn có chắc thanh toán hóa đơn cho bàn {0}\nTổng tiền - (Tổng tiền / 100) x Giảm giá\n=> {1} - ({1} / 100) x {2} = {3}",table.Name, totalPrice, discount, finalTotalPrice), "Thông báo", MessageBoxButtons.OKCancel) == System.Windows.Forms.DialogResult.OK)
{
BillDAO.Instance.CheckOut(idBill, discount);
ShowBill(table.ID);
LoadTable();
}
}
}
private void btnSwitchTable_Click(object sender, EventArgs e)
{
int id1 = (lsvBill.Tag as Table).ID;
int id2 = (cbSwitchTable.SelectedItem as Table).ID;
if (MessageBox.Show(string.Format("Bạn có thật sự muốn chuyển bàn {0} qua bàn {1}", (lsvBill.Tag as Table).Name, (cbSwitchTable.SelectedItem as Table).Name), "Thông báo", MessageBoxButtons.OKCancel) == System.Windows.Forms.DialogResult.OK)
{
TableDAO.Instance.SwitchTable(id1, id2);
LoadTable();
}
}
#endregion
}
}
Code fTableManager.Designer.cs
namespace QuanLyQuanCafe
{
partial class fTableManager
{
/// <summary>
/// Required designer variable.
/// </summary>
private System.ComponentModel.IContainer components = null;
/// <summary>
/// Clean up any resources being used.
/// </summary>
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
protected override void Dispose(bool disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Windows Form Designer generated code
/// <summary>
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
/// </summary>
private void InitializeComponent()
{
this.menuStrip1 = new System.Windows.Forms.MenuStrip();
this.adminToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
this.thôngTinTàiKhoảnToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
this.thôngTinCáNhânToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
this.đăngXuấtToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
this.panel2 = new System.Windows.Forms.Panel();
this.lsvBill = new System.Windows.Forms.ListView();
this.columnHeader1 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
this.columnHeader2 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
this.columnHeader3 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
this.columnHeader4 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
this.panel3 = new System.Windows.Forms.Panel();
this.txbTotalPrice = new System.Windows.Forms.TextBox();
this.cbSwitchTable = new System.Windows.Forms.ComboBox();
this.btnSwitchTable = new System.Windows.Forms.Button();
this.nmDisCount = new System.Windows.Forms.NumericUpDown();
this.btnDiscount = new System.Windows.Forms.Button();
this.btnCheckOut = new System.Windows.Forms.Button();
this.panel4 = new System.Windows.Forms.Panel();
this.nmFoodCount = new System.Windows.Forms.NumericUpDown();
this.btnAddFood = new System.Windows.Forms.Button();
this.cbFood = new System.Windows.Forms.ComboBox();
this.cbCategory = new System.Windows.Forms.ComboBox();
this.flpTable = new System.Windows.Forms.FlowLayoutPanel();
this.menuStrip1.SuspendLayout();
this.panel2.SuspendLayout();
this.panel3.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.nmDisCount)).BeginInit();
this.panel4.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.nmFoodCount)).BeginInit();
this.SuspendLayout();
//
// menuStrip1
//
this.menuStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
this.adminToolStripMenuItem,
this.thôngTinTàiKhoảnToolStripMenuItem});
this.menuStrip1.Location = new System.Drawing.Point(0, 0);
this.menuStrip1.Name = "menuStrip1";
this.menuStrip1.Size = new System.Drawing.Size(797, 24);
this.menuStrip1.TabIndex = 1;
this.menuStrip1.Text = "menuStrip1";
//
// adminToolStripMenuItem
//
this.adminToolStripMenuItem.Name = "adminToolStripMenuItem";
this.adminToolStripMenuItem.Size = new System.Drawing.Size(55, 20);
this.adminToolStripMenuItem.Text = "Admin";
this.adminToolStripMenuItem.Click += new System.EventHandler(this.adminToolStripMenuItem_Click);
//
// thôngTinTàiKhoảnToolStripMenuItem
//
this.thôngTinTàiKhoảnToolStripMenuItem.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] {
this.thôngTinCáNhânToolStripMenuItem,
this.đăngXuấtToolStripMenuItem});
this.thôngTinTàiKhoảnToolStripMenuItem.Name = "thôngTinTàiKhoảnToolStripMenuItem";
this.thôngTinTàiKhoảnToolStripMenuItem.Size = new System.Drawing.Size(123, 20);
this.thôngTinTàiKhoảnToolStripMenuItem.Text = "Thông tin tài khoản";
//
// thôngTinCáNhânToolStripMenuItem
//
this.thôngTinCáNhânToolStripMenuItem.Name = "thôngTinCáNhânToolStripMenuItem";
this.thôngTinCáNhânToolStripMenuItem.Size = new System.Drawing.Size(171, 22);
this.thôngTinCáNhânToolStripMenuItem.Text = "Thông tin cá nhân";
this.thôngTinCáNhânToolStripMenuItem.Click += new System.EventHandler(this.thôngTinCáNhânToolStripMenuItem_Click);
//
// đăngXuấtToolStripMenuItem
//
this.đăngXuấtToolStripMenuItem.Name = "đăngXuấtToolStripMenuItem";
this.đăngXuấtToolStripMenuItem.Size = new System.Drawing.Size(171, 22);
this.đăngXuấtToolStripMenuItem.Text = "Đăng xuất";
this.đăngXuấtToolStripMenuItem.Click += new System.EventHandler(this.đăngXuấtToolStripMenuItem_Click);
//
// panel2
//
this.panel2.Controls.Add(this.lsvBill);
this.panel2.Location = new System.Drawing.Point(447, 85);
this.panel2.Name = "panel2";
this.panel2.Size = new System.Drawing.Size(338, 315);
this.panel2.TabIndex = 2;
//
// lsvBill
//
this.lsvBill.Columns.AddRange(new System.Windows.Forms.ColumnHeader[] {
this.columnHeader1,
this.columnHeader2,
this.columnHeader3,
this.columnHeader4});
this.lsvBill.GridLines = true;
this.lsvBill.Location = new System.Drawing.Point(3, 3);
this.lsvBill.Name = "lsvBill";
this.lsvBill.Size = new System.Drawing.Size(332, 309);
this.lsvBill.TabIndex = 0;
this.lsvBill.UseCompatibleStateImageBehavior = false;
this.lsvBill.View = System.Windows.Forms.View.Details;
//
// columnHeader1
//
this.columnHeader1.Text = "Tên món";
this.columnHeader1.Width = 133;
//
// columnHeader2
//
this.columnHeader2.Text = "Số lượng";
//
// columnHeader3
//
this.columnHeader3.Text = "Đơn giá";
this.columnHeader3.Width = 54;
//
// columnHeader4
//
this.columnHeader4.Text = "Thành tiền";
this.columnHeader4.Width = 81;
//
// panel3
//
this.panel3.Controls.Add(this.txbTotalPrice);
this.panel3.Controls.Add(this.cbSwitchTable);
this.panel3.Controls.Add(this.btnSwitchTable);
this.panel3.Controls.Add(this.nmDisCount);
this.panel3.Controls.Add(this.btnDiscount);
this.panel3.Controls.Add(this.btnCheckOut);
this.panel3.Location = new System.Drawing.Point(447, 406);
this.panel3.Name = "panel3";
this.panel3.Size = new System.Drawing.Size(338, 52);
this.panel3.TabIndex = 3;
//
// txbTotalPrice
//
this.txbTotalPrice.Font = new System.Drawing.Font("Arial", 11.25F, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, ((byte)(163)));
this.txbTotalPrice.ForeColor = System.Drawing.Color.OrangeRed;
this.txbTotalPrice.Location = new System.Drawing.Point(164, 17);
this.txbTotalPrice.Name = "txbTotalPrice";
this.txbTotalPrice.ReadOnly = true;
this.txbTotalPrice.Size = new System.Drawing.Size(90, 25);
this.txbTotalPrice.TabIndex = 7;
this.txbTotalPrice.Text = "0";
this.txbTotalPrice.TextAlign = System.Windows.Forms.HorizontalAlignment.Right;
//
// cbSwitchTable
//
this.cbSwitchTable.FormattingEnabled = true;
this.cbSwitchTable.Location = new System.Drawing.Point(3, 28);
this.cbSwitchTable.Name = "cbSwitchTable";
this.cbSwitchTable.Size = new System.Drawing.Size(75, 21);
this.cbSwitchTable.TabIndex = 6;
//
// btnSwitchTable
//
this.btnSwitchTable.Location = new System.Drawing.Point(3, 3);
this.btnSwitchTable.Name = "btnSwitchTable";
this.btnSwitchTable.Size = new System.Drawing.Size(75, 26);
this.btnSwitchTable.TabIndex = 5;
this.btnSwitchTable.Text = "Chuyển bàn";
this.btnSwitchTable.UseVisualStyleBackColor = true;
this.btnSwitchTable.Click += new System.EventHandler(this.btnSwitchTable_Click);
//
// nmDisCount
//
this.nmDisCount.Location = new System.Drawing.Point(84, 29);
this.nmDisCount.Name = "nmDisCount";
this.nmDisCount.Size = new System.Drawing.Size(74, 20);
this.nmDisCount.TabIndex = 4;
this.nmDisCount.TextAlign = System.Windows.Forms.HorizontalAlignment.Center;
//
// btnDiscount
//
this.btnDiscount.Location = new System.Drawing.Point(84, 3);
this.btnDiscount.Name = "btnDiscount";
this.btnDiscount.Size = new System.Drawing.Size(75, 26);
this.btnDiscount.TabIndex = 4;
this.btnDiscount.Text = "Giảm giá";
this.btnDiscount.UseVisualStyleBackColor = true;
//
// btnCheckOut
//
this.btnCheckOut.Location = new System.Drawing.Point(260, 3);
this.btnCheckOut.Name = "btnCheckOut";
this.btnCheckOut.Size = new System.Drawing.Size(75, 46);
this.btnCheckOut.TabIndex = 3;
this.btnCheckOut.Text = "Thanh toán";
this.btnCheckOut.UseVisualStyleBackColor = true;
this.btnCheckOut.Click += new System.EventHandler(this.btnCheckOut_Click);
//
// panel4
//
this.panel4.Controls.Add(this.nmFoodCount);
this.panel4.Controls.Add(this.btnAddFood);
this.panel4.Controls.Add(this.cbFood);
this.panel4.Controls.Add(this.cbCategory);
this.panel4.Location = new System.Drawing.Point(447, 27);
this.panel4.Name = "panel4";
this.panel4.Size = new System.Drawing.Size(338, 52);
this.panel4.TabIndex = 4;
//
// nmFoodCount
//
this.nmFoodCount.Location = new System.Drawing.Point(296, 19);
this.nmFoodCount.Minimum = new decimal(new int[] {
100,
0,
0,
-2147483648});
this.nmFoodCount.Name = "nmFoodCount";
this.nmFoodCount.Size = new System.Drawing.Size(39, 20);
this.nmFoodCount.TabIndex = 3;
this.nmFoodCount.Value = new decimal(new int[] {
1,
0,
0,
0});
//
// btnAddFood
//
this.btnAddFood.Location = new System.Drawing.Point(214, 3);
this.btnAddFood.Name = "btnAddFood";
this.btnAddFood.Size = new System.Drawing.Size(75, 46);
this.btnAddFood.TabIndex = 2;
this.btnAddFood.Text = "Thêm món";
this.btnAddFood.UseVisualStyleBackColor = true;
this.btnAddFood.Click += new System.EventHandler(this.btnAddFood_Click);
//
// cbFood
//
this.cbFood.FormattingEnabled = true;
this.cbFood.Location = new System.Drawing.Point(3, 28);
this.cbFood.Name = "cbFood";
this.cbFood.Size = new System.Drawing.Size(205, 21);
this.cbFood.TabIndex = 1;
//
// cbCategory
//
this.cbCategory.FormattingEnabled = true;
this.cbCategory.Location = new System.Drawing.Point(3, 3);
this.cbCategory.Name = "cbCategory";
this.cbCategory.Size = new System.Drawing.Size(205, 21);
this.cbCategory.TabIndex = 0;
this.cbCategory.SelectedIndexChanged += new System.EventHandler(this.cbCategory_SelectedIndexChanged);
//
// flpTable
//
this.flpTable.AutoScroll = true;
this.flpTable.Location = new System.Drawing.Point(12, 30);
this.flpTable.Name = "flpTable";
this.flpTable.Size = new System.Drawing.Size(429, 428);
this.flpTable.TabIndex = 5;
//
// fTableManager
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(797, 470);
this.Controls.Add(this.flpTable);
this.Controls.Add(this.panel4);
this.Controls.Add(this.panel3);
this.Controls.Add(this.panel2);
this.Controls.Add(this.menuStrip1);
this.MainMenuStrip = this.menuStrip1;
this.Name = "fTableManager";
this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen;
this.Text = "Phần mềm quản lý quán cafe";
this.menuStrip1.ResumeLayout(false);
this.menuStrip1.PerformLayout();
this.panel2.ResumeLayout(false);
this.panel3.ResumeLayout(false);
this.panel3.PerformLayout();
((System.ComponentModel.ISupportInitialize)(this.nmDisCount)).EndInit();
this.panel4.ResumeLayout(false);
((System.ComponentModel.ISupportInitialize)(this.nmFoodCount)).EndInit();
this.ResumeLayout(false);
this.PerformLayout();
}
#endregion
private System.Windows.Forms.MenuStrip menuStrip1;
private System.Windows.Forms.ToolStripMenuItem adminToolStripMenuItem;
private System.Windows.Forms.ToolStripMenuItem thôngTinTàiKhoảnToolStripMenuItem;
private System.Windows.Forms.ToolStripMenuItem thôngTinCáNhânToolStripMenuItem;
private System.Windows.Forms.ToolStripMenuItem đăngXuấtToolStripMenuItem;
private System.Windows.Forms.Panel panel2;
private System.Windows.Forms.ListView lsvBill;
private System.Windows.Forms.Panel panel3;
private System.Windows.Forms.Panel panel4;
private System.Windows.Forms.NumericUpDown nmFoodCount;
private System.Windows.Forms.Button btnAddFood;
private System.Windows.Forms.ComboBox cbFood;
private System.Windows.Forms.ComboBox cbCategory;
private System.Windows.Forms.ComboBox cbSwitchTable;
private System.Windows.Forms.Button btnSwitchTable;
private System.Windows.Forms.NumericUpDown nmDisCount;
private System.Windows.Forms.Button btnDiscount;
private System.Windows.Forms.Button btnCheckOut;
private System.Windows.Forms.FlowLayoutPanel flpTable;
private System.Windows.Forms.ColumnHeader columnHeader1;
private System.Windows.Forms.ColumnHeader columnHeader2;
private System.Windows.Forms.ColumnHeader columnHeader3;
private System.Windows.Forms.ColumnHeader columnHeader4;
private System.Windows.Forms.TextBox txbTotalPrice;
}
}
Code BillDAO.cs
using QuanLyQuanCafe.DTO;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace QuanLyQuanCafe.DAO
{
public class BillDAO
{
private static BillDAO instance;
public static BillDAO Instance
{
get { if (instance == null) instance = new BillDAO(); return BillDAO.instance; }
private set { BillDAO.instance = value; }
}
private BillDAO() { }
/// <summary>
/// Thành công: bill ID
/// thất bại: -1
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public int GetUncheckBillIDByTableID(int id)
{
DataTable data = DataProvider.Instance.ExecuteQuery("SELECT * FROM dbo.Bill WHERE idTable = " + id +" AND status = 0");
if (data.Rows.Count > 0)
{
Bill bill = new Bill(data.Rows[0]);
return bill.ID;
}
return -1;
}
public void CheckOut(int id, int discount)
{
string query = "UPDATE dbo.Bill SET status = 1, " + "discount = " + discount + " WHERE id = " + id;
DataProvider.Instance.ExecuteNonQuery(query);
}
public void InsertBill(int id)
{
DataProvider.Instance.ExecuteNonQuery("exec USP_InsertBill @idTable", new object[]{id});
}
public int GetMaxIDBill()
{
try
{
return (int)DataProvider.Instance.ExecuteScalar("SELECT MAX(id) FROM dbo.Bill");
}
catch
{
return 1;
}
}
}
}
Code Bill.cs
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace QuanLyQuanCafe.DTO
{
public class Bill
{
public Bill(int id, DateTime? dateCheckin, DateTime? dateCheckOut, int status, int discount = 0)
{
this.ID = id;
this.DateCheckIn = dateCheckin;
this.DateCheckOut = dateCheckOut;
this.Status = status;
this.Discount = discount;
}
public Bill(DataRow row)
{
this.ID = (int)row["id"];
this.DateCheckIn = (DateTime?)row["dateCheckin"];
var dateCheckOutTemp = row["dateCheckOut"];
if (dateCheckOutTemp.ToString() != "")
this.DateCheckOut = (DateTime?)dateCheckOutTemp;
this.Status = (int)row["status"];
if (row["discount"].ToString() != "")
this.Discount = (int)row["discount"];
}
private int discount;
public int Discount
{
get { return discount; }
set { discount = value; }
}
private int status;
public int Status
{
get { return status; }
set { status = value; }
}
private DateTime? dateCheckOut;
public DateTime? DateCheckOut
{
get { return dateCheckOut; }
set { dateCheckOut = value; }
}
private DateTime? dateCheckIn;
public DateTime? DateCheckIn
{
get { return dateCheckIn; }
set { dateCheckIn = value; }
}
private int iD;
public int ID
{
get { return iD; }
set { iD = value; }
}
}
}
Code TableDAO.cs
using QuanLyQuanCafe.DTO;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace QuanLyQuanCafe.DAO
{
public class TableDAO
{
private static TableDAO instance;
public static TableDAO Instance
{
get { if (instance == null) instance = new TableDAO(); return TableDAO.instance; }
private set { TableDAO.instance = value; }
}
public static int TableWidth = 90;
public static int TableHeight = 90;
private TableDAO() { }
public void SwitchTable(int id1, int id2)
{
DataProvider.Instance.ExecuteQuery("USP_SwitchTabel @idTable1 , @idTabel2", new object[]{id1, id2});
}
public List<Table> LoadTableList()
{
List<Table> tableList = new List<Table>();
DataTable data = DataProvider.Instance.ExecuteQuery("USP_GetTableList");
foreach (DataRow item in data.Rows)
{
Table table = new Table(item);
tableList.Add(table);
}
return tableList;
}
}
}
Bài sau chúng ta sẽ cùng nhau tìm hiểu cách hiển thị danh sách hóa đơn theo ngày.
Đừng quên: “Luyện tập – Thử thách – Không ngại khó”
Tải xuống
Tài liệu
Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Chuyển bàn trong phần mềm Quản lý quán cafe với C# Winform dưới dạng file PDF trong link bên dưới.
Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com
Đừng quên like và share để ủng hộ Kteam và tác giả nhé!

Thảo luận
Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.
Nội dung bài viết
Tác giả/Dịch giả
Khóa học
Lập trình phần mềm Quản lý quán cafe với C# Winform
Bạn đã học qua LẬP TRÌNH C# CƠ BẢN? Xong nốt cả LẬP TRÌNH WINFORM lẫn SQL?
Bạn đã chán các bài tập căn bản, muốn thực hành các kiến thức đã học vào một dự án thực tế?
Hay đơn giản bạn là chủ quán café, mong muốn tự tạo nên phần mềm dành cho chính mình sử dụng?
Vậy còn chần chừ gì không tham gia ngay khóa học LẬP TRÌNH PHẦN MỀM QUÁN CAFÉ VỚI C# WINFORM?
Sửa lỗi này làm sao vậy mọi người giúp em với ạ
Mình lấy code của bạn dưới để chỉnh lại cho nó đầy đủ hơn về gộp bàn :
Chia sẻ với các bạn code của mình, lí thuyết chuyển bàn như sau: (CSDL mình đặt tên khác với bài nhưng ý nghĩa cũng tương tự)
1. Chỉ chuyển bàn có người sang bàn trống hoặc 2 bàn có người chuyển qua lại cho nhau. (vì thực tế bàn trống thì chuyển cái gì?) Thêm dòng sau ở event button chuyển bàn, sau phần khai báo biến để tránh lỗi do bấm nhầm: (và phải chọn bàn có người ở listview trước)
2. Như trên ta có 2 trường hợp. Nếu bàn 1 có người chuyển qua bàn 2 trống, thì idtable2 NULL, nếu 2 bàn có người thì không có idtable nào NULL cả. Stored Procedure sp_SwitchTable như sau: Lưu ý khi viết SP này:
- Vòng IF của trường hợp 2 bàn có người phải nằm trước trường hợp 1 bàn có người, do SP chạy từ trên xuống nên nếu đặt ngược lại vẫn chạy cả 2 vòng IF.
- Đối với trường hợp chuyển 1 bàn có người sang 1 bàn trống, thuật toán là xóa đi bàn đã chuyển & tạo trigger để cập nhật lại trạng thái bàn trống cho bảng Bill.
Trigger set trạng thái bàn về trống sau khi xóa đi bàn ban đầu trong trường hợp chuyển 1 bàn có người sang 1 bàn khác trống. Đồng thời cũng thêm 1 phần bị lỗi khi thanh toán xong bàn vẫn có người do Trigger của BillInfo làm.
Còn trigger cho BillInfo thì giống trong bài viết. Cảm ơn các bạn đã xem.
Có bạn nào làm được phần Gộp bàn chưa nhỉ?
có ai biết lỗi mà ko chuyển được bàn không mọi người ko báo lỗi gì nhưng ko chuyển đc bàn