便利店神器 --- 收银台系统

 收银台作为便利店不可少的配套设施,是顾客结账的地方,他的效率好坏也就简洁的影响着便利店的利润,速度快,顾客不滞留,速度慢了会因为等待结账时间过长,顾客放弃购买,利润受损。
 本篇文章涉及的收银台系统方便快捷地查出顾客结帐情况,商品信息情况,每天的售货情况,方便了对超市商品管理、人员管理,大大提高了超市的售货速度。

核心功能

登录

我们使用的CEditUI控件的GetText()接口拿到用户名和密码,拼接SQL语句,在职工表中查询对比输入的信息,登录到不同的界面,如果职工表中没有该条查询的信息则输出用户名或密码错误。

//获取用户名
CEditUI* pEditUserName = (CEditUI*)m_PaintManager.FindControl(_T("EDIT_USER_NAME"));
CDuiString strUserName = pEditUserName->GetText();
//获取密码
CEditUI* pEditPassword = (CEditUI*)m_PaintManager.FindControl(_T("EDIT_USER_PASSWORD"));
CDuiString strPassword = pEditPassword->GetText();

管理员界面

 通过获取各个控件的输入信息,拼接SQL语句
 查询:分为无条件查询和条件查询
 插入:拼接SQL语句,插入到职工表中
 更新:更新电话,薪资等
 删除:点击界面上列表显示的信息,获得行数,获取名字,拼接SQL语句,完成删除
 销售记录:将销售记录放到列表中

售货员界面

  拿到商品名称,拼接SQL语句,查询库存,如果低于阈值,会提示进货
 +/- :是获取购买的数量,实时更新库存
 确认之后会将信息显示到当前界面
 确认交易后会有合计显示到当前界面,并拼接SQL语句,并插入到销售记录的表中
 取消交易后会清空列表

数据库设计

 我们会涉及到四张表,其中有职工信息表,商品信息表,会员表,销售记录表
在这里插入图片描述
 表的具体结构

商品表

create table employee(
		id int,                       -- 员工编号
	  	name varchar(20),             -- 员工名字 
  		gender varchar(3),            -- 员工性别 
 		birthday Date,                -- 生日
   		password varchar(20),         -- 员工密码
    	position varchar(10),         -- 员工职位
 		telphone varchar(11),         -- 联系方式 
 		salary double(9,2)            -- 联系方式
 		 );

商品表

create table Goods(
 	GoodsID int,                     -- 商品编号 
 	GoodsName varchar(20),           -- 商品名称 
 	GoodsType varchar(20),           -- 商品类别:水果、烟酒、日常用品、副食等 
	ProductDate DATE,                -- 商品生产日期
	DeadDate DATE,                   -- 商品过期日期 
 	Price double(9,2),               -- 商品价格 
 	Unit  varchar(3),                -- 计量单位 
 	Inventory int,                   -- 库存量:商品剩余数量 
 	AlarmValye int                   -- 报警值:低于该值时,应提醒管理员进货
 	 );

销售记录表

create table SellRecord( 
	GoodsName varchar(20),    -- 商品名称 
	GoodsPrice double(9, 2),  -- 商品价格 
	Amount int,               -- 售出数量 
	Unit varchar(3),          -- 计量单位 
	SellTime Date,            -- 售出时间 
	Operator varchar(20);    -- 售货员
	);

会员表

create table Member(    
	Name varchar(20),    -- 会员名字    
	Telphone varchar(20), -- 会员电话   
 	Level, int            -- 会员级别    
 	Score, int            -- 会员积分    
 	Time,  Date           -- 办理会员日期 
 );

Duilib界面库

 Duilib 是一款强大的界面开发工具,可以将用户界面和处理逻辑彻底分离,极大地提高用户界面的开发效率。
在这里插入图片描述
 在右下角的控件框中选择我们所需要的控件,直接拖动即可。
 本项目中,我们只要用控件Edit做为信息的输入,在代码中根据控件名称找到该控件,获取输入内容,同理,用控件Button来响应各个函数,用控件Label来显示提示信息,控件Option作为下拉框,通过修改xml文件为下拉框填充内容,控件List把查询信息显示出来,在此处也要通过修改xml文件来增加list列表的各个条目。
 比如list:我们用ListHeaderItem 给列表添加头部信息,itemalign="center"使数据居中显示

  <List name="OrderList" itemalign="center" width="760" height="440" itemtextcolor="#FF000000" itemselectedtextcolor="#FF000000" itemselectedbkcolor="#FFC1E3FF" itemhottextcolor="#FF000000" itemhotbkcolor="#FFE9F5FF" itemdisabledtextcolor="#FFCCCCCC" itemdisabledbkcolor="#FFFFFFFF">
                  <ListHeader>
                    <ListHeaderItem text="商品名称" width="170" height="40" minwidth="16" textcolor="#FF000000" sepwidth="4" align="center" />
                    <ListHeaderItem text="价格" width="152" height="40" minwidth="16" textcolor="#FF000000" sepwidth="4" align="center" />
                    <ListHeaderItem text="数量" width="135" height="40" minwidth="16" textcolor="#FF000000" sepwidth="4" align="center" />
                    <ListHeaderItem text="单位" width="145" height="40" minwidth="16" textcolor="#FF000000" sepwidth="4" align="center" />
                    <ListHeaderItem text="合计" width="158" height="40" minwidth="16" textcolor="#FF000000" sepwidth="4" align="center" />
                </ListHeader>
   </List>

 我们使用Duilib主要是方便,很方便做出我们所需要的界面,在代码中也只需要简单的几行代码就可以拿到我们所需要的信息,减少了很多麻烦事。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值