/// <summary> /// SaveSalerInfo: /// 【1】AddSalesList销售主表:以发票的形式记录消费的客户的小票数据,放在SalesList表里面记录客户的买的东西 /// 【2】AddSalesListDetail商品销售统计表:就是顾客买的东西记录一下,放在AddSalesListDetail表里面记录收银员的给客户卖东西是的账本 /// 【3】RefreshMemberPoint修改会员积分:如果有会员则修改会员积分 /// </summary> /// <param name="sales"></param> /// <param name="members"></param> /// <returns></returns> public bool SaveSalerInfo(SalesListModel1 sales, SMMembersModel10 members) { return(server.SaveSalerInfo(sales, members)); }
//【1.1】到【1.5】先搭建构架;还没有实现存储过程 //【1.1】到【1.4】取消结算 //【1.5】到【1.20】正式开始结算([包含了客户卖东西的数据库中的表]和[收银员记录客户消费具体的信息表在数据库中显示]和[VIP会员的积分记录]) private void Balance() { //【1.1】 //显示结算窗口,考虑支付被取消或修改,并传递txtPay应付多少钱文本框 FrmBalance frm = new FrmBalance(txtPay.Text); //【1.2】 //如果打开FrmBalance不成功进入 if (frm.ShowDialog() != DialogResult.OK) { //客户放弃购买(忘记带钱等);在购买界面时键盘上按了Escape按钮,给Tag传了一个Tag数据,则frm.Tag.ToString() == "Esc"现在相等,进入if语句 //【1.3】 if (frm.Tag.ToString() == "Esc") { //【1.4】 //支付完成重置界面:就是把原有的界面里面的商品清空,从新开始 RestForm();//【二】弄完后进入【三.1】FrmBalance窗口里 } } //【1.5】 else//正式进入结算环节 { //【1.6】 //实例化会员类 SMMembersModel10 members = null; //Contains("&")表示&这个字符是否出现在此字符串中 //【1.7】 //获取含有&tag值 if (frm.Tag.ToString().Contains("&"))//输入了会员卡号 { //【1.8】 //把含有&的Tag值,分割两部分,用string数组记录 //这两部分分别是【客户实际付的钱数】和【VIP的编号】 string[] info = frm.Tag.ToString().Split('&'); //【1.9】【客户实际付的钱数】 txtAmount.Text = info[0]; //【1.10】 members = new SMMembersModel10() { //【1.11】【VIP的编号】 MemberId = info[1], //【1.12】给具体购买的商品的总金额/10 Points = (int)(Convert.ToDouble(txtPay.Text) / 10.0) }; } else { //【1.13】没有会员,直接获取【客户实际付的钱数】 txtAmount.Text = frm.Tag.ToString(); } //【1.14】 //找零 //【客户实际付的钱数】-【具体购买的商品的总金额】 txtChange.Text = (Convert.ToDecimal(txtAmount.Text) - Convert.ToDecimal(txtPay.Text)).ToString(); /*txtChange.Text = (Convert.ToDecimal(txtPay.Text) - Convert.ToDecimal(txtAmount.Text)).ToString();*/ //【1.15】上面弄完后,saleObj的每个数据就会附上具体的数据 //创建消费对象 SalesListModel1 saleObj = new SalesListModel1() { SerialNum = txtSerialNum.Text, TotalMoney = Convert.ToDecimal(txtPay.Text.Trim()), RealReceive = Convert.ToDecimal(txtAmount.Text.Trim()), ReturnMoney = Convert.ToDecimal(txtChange.Text.Trim()), SalesPersonId = Program.Seles.SalesPersonId }; //【1.16】 //封装消费明细列表 //productList放商品的具体数据盒子 foreach (ProdutsModel item in productList) { //【1.17】 //给saleObj里面的ListDetail属性里面添加方法 //ListDetail就是SalesListDetailModel的接收容器 //给 saleObj.ListDetail.Add里面添加new SalesListDetailModel(){}的原因是saleObj.ListDetail这个方法接收的是SalesListDetailModel类型的泛型所以用new SalesListDetailModel(){}添加 saleObj.ListDetail.Add( //【1.18】 new SalesListDetailModel() { //把商品列表中的所有信息给了SalesListDetailModel类里面 SerialNum = txtSerialNum.Text, ProductId = item.ProductId, ProductName = item.ProductName, Quantity = item.Quantity, UnitPrice = item.UnitPrice, Discount = item.Discount, SubTotalMoney = item.SubTotal } ); } try { //【1.19】 /// <summary> /// SaveSalerInfo: /// 【1】AddSalesList销售主表:以发票的形式记录消费的客户的小票数据,放在SalesList表里面记录客户的买的东西 /// 【2】AddSalesListDetail商品销售统计表:就是顾客买的东西记录一下,放在AddSalesListDetail表里面记录收银员的给客户卖东西是的账本 /// 【3】RefreshMemberPoint修改会员积分:如果有会员则修改会员积分 /// </summary> //把结算的内容相互通过数据库事务相互牵连 //saleObj(包含了在主窗口中文本框中的所有数据,还获取了ListDetail里面添加的所有数据)获取所有的商品表并数据传递到数据库里 //members把会员所需要的数据传递到数据库里 manager2.SaveSalerInfo(saleObj, members); } //【1.20】 catch (Exception ex) { MessageBox.Show($"保存销售数据的时候发生异常!{ex.Message}", "异常提示"); return; } //小票打印 //【1】在工具箱里获取打印工具printDocument(printDocument打印工具的名字) //【3】Print开始文档的打印进程 printDocument.Print(); //【4】小票打印预览 PrintPriview(); //重置主界面 RestForm(); } }
/// <summary> /// 【1】AddSalesList销售主表:以发票的形式记录消费的客户的小票数据,放在SalesList表里面记录客户的买的东西 /// 【2】AddSalesListDetail商品销售统计表:就是顾客买的东西记录一下,放在AddSalesListDetail表里面记录收银员的给客户卖东西是的账本 /// 【3】RefreshMemberPoint修改会员积分:如果有会员则修改会员积分 /// </summary> /// <param name="sales">sales(包含了在主窗口中文本框中的所有数据,还获取了ListDetail里面添加的所有数据)获取所有的商品表并数据传递到数据库里</param> /// <param name="members"></param> /// <returns></returns> public bool SaveSalerInfo(SalesListModel1 sales, SMMembersModel10 members) { //【4月8日】 List <string> procList = new List <string>(); List <SqlParameter[]> psList = new List <SqlParameter[]>(); //给消费主表中添加数据 procList.Add("AddSalesList"); //【1】 SqlParameter[] saleSp = new SqlParameter[] { new SqlParameter("@SerialNum", SqlDbType.NVarChar, 50), new SqlParameter("@TotalMoney", SqlDbType.Decimal), new SqlParameter("@RealReceive", SqlDbType.Decimal), new SqlParameter("@ReturnMoney", SqlDbType.Decimal), new SqlParameter("@SalesPersonId", SqlDbType.Int) }; saleSp[0].Value = sales.SerialNum; saleSp[1].Value = sales.TotalMoney; saleSp[2].Value = sales.RealReceive; saleSp[3].Value = sales.ReturnMoney; saleSp[4].Value = sales.SalesPersonId; // 把参数对应的值放在psList里面 psList.Add(saleSp); //【2】 //通过SalesListModel1也可以知道SalesListDetailModel里面对应的值 //给消费明细表中添加每次购物的详细数据 foreach (SalesListDetailModel detail in sales.ListDetail) { procList.Add("AddSalesListDetail"); SqlParameter[] detailList = new SqlParameter[] { new SqlParameter("@SerialNum", SqlDbType.NVarChar, 50), new SqlParameter("@ProductId", SqlDbType.NVarChar, 50), new SqlParameter("@ProductName", SqlDbType.NVarChar, 50), new SqlParameter("@UnitPrice", SqlDbType.Decimal), new SqlParameter("@Discount", SqlDbType.Float), new SqlParameter("@Quantity", SqlDbType.Int), new SqlParameter("@SubTotalMoney", SqlDbType.Decimal) }; detailList[0].Value = detail.SerialNum; detailList[1].Value = detail.ProductId; detailList[2].Value = detail.ProductName; detailList[3].Value = detail.UnitPrice; detailList[4].Value = detail.Discount; detailList[5].Value = detail.Quantity; detailList[6].Value = detail.SubTotalMoney; psList.Add(detailList); //【4月9日】 //更新库存数据:就是对商品数量的改变 procList.Add("InventoryOut"); SqlParameter[] inventorySp = new SqlParameter[] { new SqlParameter("@ProductId", SqlDbType.NVarChar, 50), new SqlParameter("@TotalCount", SqlDbType.Int) }; inventorySp[0].Value = detail.ProductId; inventorySp[1].Value = detail.Quantity; psList.Add(inventorySp); } //【4月8日】 //【3】 //更新会员的积分 if (members != null) { procList.Add("RefreshMemberPoint"); SqlParameter[] memberSp = new SqlParameter[] { new SqlParameter("@point", SqlDbType.Int), new SqlParameter("@memberId", SqlDbType.Int) }; memberSp[0].Value = members.Points; memberSp[1].Value = members.MemberId; psList.Add(memberSp); } return(SQLHelper.UpdateByTran(procList, psList)); }