springboot vue 开源 会员收银系统 (7) 收银台的完善 新增开卡 结算
前言
完整版演示
开发版演示
在前面的开发中,我们成功完成了商品分类和商品信息的搭建,开发了收银台基础。现在,我们将进一步完善收银台的功能,添加开卡和结算功能,并在后台实现会员卡的创建和订单保存。同时,我们还将保存页面vue data数据用于修改订单
1.收银台添加开卡功能 后期不仅限开发 还有续卡 套餐…

2.结算后需要生成订单在此注意几个订单的问题
- 需要有主订单表 一个订单有多个商品需要创建一个订单详情表与之关联
- 还需要创建一个支付方式表 一个订单有多种支付方式
- 订单表需要关联会员id便于筛查和查询消费记录
- 添加状态字段用于消单、改单 (并创建一个表保存当前vue实例的data用于修改订单)
以下为相关表格
CREATE TABLE `business_sell` (`SELL_ID` varchar(32) NOT NULL COMMENT '订单id',`SELL_NO` varchar(255) DEFAULT NULL COMMENT '订单号',`SERIAL_NO` varchar(32) DEFAULT NULL COMMENT '流水号',`MEMBER_ID` varchar(32) DEFAULT NULL COMMENT '会员ID',`MEMBER_NAME` varchar(255) DEFAULT NULL COMMENT '会员名称',`MEMBER_CARD_ID` varchar(32) DEFAULT NULL COMMENT '会员卡id',`SELL_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '消费金额',`REAL_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '实际入账',`SELL_TYPE` tinyint(2) DEFAULT NULL COMMENT '1开卡 2续卡 3项目/卖品',`SELL_STATUS` tinyint(2) DEFAULT '0' COMMENT '0正常 1取消',`DELETED` tinyint(2) DEFAULT '0' COMMENT '0正常 1删除',`VERSION` bigint(10) DEFAULT '0' COMMENT '乐观锁字段',`SHOP_ID` varchar(32) DEFAULT NULL COMMENT '门店id',`SHOP_NAME` varchar(255) DEFAULT NULL COMMENT '门店名',`CREATE_NAME` varchar(255) DEFAULT NULL COMMENT '创建人',`CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',`CREATE_ID` varchar(32) DEFAULT NULL COMMENT '创建人id',`UPDATE_TIME` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',`UPDATE_NAME` varchar(255) DEFAULT NULL COMMENT '修改人',`UPDATE_ID` varchar(32) DEFAULT NULL COMMENT '修改人id',`MEMBER_CARD_AFTER_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '消费后金额',`MEMBER_CARD_BEFORE_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '消费前赠送金额',`MEMBER_CARD_BEFORE_GIVE_AMOUNT` decimal(10,2) DEFAULT NULL,`MEMBER_CARD_AFTER_GIVE_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '消费后赠送金额',PRIMARY KEY (`SELL_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='订单';
CREATE TABLE `business_sell_detail` (`SELL_DETAIL_ID` varchar(32) NOT NULL COMMENT '销售细单id',`MEMBER_ID` varchar(32) DEFAULT NULL COMMENT '会员id',`SELL_ID` varchar(32) DEFAULT NULL COMMENT '订单id',`SELL_TYPE` tinyint(2) DEFAULT NULL COMMENT '1开卡 2续卡 3项目 4卖品',`MEMBER_CARD_ID` varchar(32) DEFAULT NULL COMMENT '会员卡id',`PRODUCT_ID` varchar(32) DEFAULT NULL COMMENT '商品ID',`PRODUCT_NAME` varchar(255) DEFAULT NULL COMMENT '商品名',`COUNT` int(10) DEFAULT '1' COMMENT '商品数量',`DISCOUNT` decimal(10,2) DEFAULT NULL COMMENT '折扣',`AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '金额',`REAL_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '实际金额',`CARD_ID` varchar(32) DEFAULT NULL COMMENT '卡项ID',`CARD_NAME` varchar(255) DEFAULT NULL COMMENT '卡名',`GIVE_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '赠送金额',`SHOP_ID` varchar(32) DEFAULT NULL COMMENT '门店id',`SHOP_NAME` varchar(255) DEFAULT NULL COMMENT '门店名',`CREATE_NAME` varchar(255) DEFAULT NULL COMMENT '创建人',`CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',`CREATE_ID` varchar(32) DEFAULT NULL COMMENT '创建人id',`UPDATE_TIME` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',`UPDATE_NAME` varchar(255) DEFAULT NULL COMMENT '修改人',`UPDATE_ID` varchar(32) DEFAULT NULL COMMENT '修改人id',`SELL_STATUS` tinyint(2) DEFAULT '0' COMMENT '0正常 1取消',PRIMARY KEY (`SELL_DETAIL_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='订单详情';
CREATE TABLE `business_sellpay` (`SELL_PAY_ID` varchar(32) NOT NULL COMMENT '支付id',`SELL_ID` varchar(32) DEFAULT NULL COMMENT '销售单id',`PAY_NAME` varchar(255) DEFAULT NULL COMMENT '支付方式名称',`PAY_TYPE` tinyint(2) DEFAULT NULL COMMENT '1.卡金 2.扫码 3.现金 888.优惠 ',`AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '金额',PRIMARY KEY (`SELL_PAY_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='订单支付';
CREATE TABLE `business_selljson` (`JSON_ID` varchar(32) NOT NULL,`SELL_ID` varchar(32) DEFAULT NULL COMMENT '订单id',`SELL_JSON` json DEFAULT NULL COMMENT '获得下订单时的JSON',PRIMARY KEY (`JSON_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='订单json';
3.订单创建完毕后还需要创建会员卡
这样后续就可以选择会员卡卡金支付了
CREATE TABLE `business_member_card` (`MEMBER_CARD_ID` varchar(32) NOT NULL COMMENT '会员卡id',`MEMBER_ID` varchar(32) DEFAULT NULL COMMENT '会员id',`CARD_ID` varchar(32) DEFAULT NULL COMMENT '卡项ID',`CARD_NO` varchar(255) DEFAULT NULL COMMENT '卡号',`CARD_NAME` varchar(255) DEFAULT NULL COMMENT '卡名称',`AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '余额',`GIVE_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '赠送金额',`DISCOUNT` decimal(10,2) DEFAULT NULL COMMENT '商品折扣',`BUILD_CARD_AMOUNT` decimal(10,2) DEFAULT NULL COMMENT '开卡金额',`PUSH_MONEY` decimal(10,2) DEFAULT NULL COMMENT '提成比例',`CARD_STATUS` tinyint(2) DEFAULT '0' COMMENT '0正常 1取消',`DELETED` tinyint(2) DEFAULT '0' COMMENT '0正常 1删除',`VERSION` bigint(10) DEFAULT '0' COMMENT '乐观锁字段',`SHOP_ID` varchar(32) DEFAULT NULL COMMENT '门店id',`SHOP_NAME` varchar(255) DEFAULT NULL COMMENT '门店名',`CREATE_NAME` varchar(255) DEFAULT NULL COMMENT '创建人',`CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',`CREATE_ID` varchar(32) DEFAULT NULL COMMENT '创建人id',`UPDATE_TIME` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',`UPDATE_NAME` varchar(255) DEFAULT NULL COMMENT '修改人',`UPDATE_ID` varchar(32) DEFAULT NULL COMMENT '修改人id',PRIMARY KEY (`MEMBER_CARD_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='会员卡';
package com.dd.admin.business.pay.service.impl;import com.dd.admin.business.card.entity.Card;
import com.dd.admin.business.card.service.CardService;
import com.dd.admin.business.memberCard.domain.MemberCardVo;
import com.dd.admin.business.memberCard.entity.MemberCard;
import com.dd.admin.business.memberCard.service.MemberCardService;
import com.dd.admin.business.pay.domain.BaseSell;
import com.dd.admin.business.pay.domain.BuildCardForm;
import com.dd.admin.business.pay.domain.BuildCardSell;
import com.dd.admin.business.pay.service.AddSellDetailService;
import com.dd.admin.business.sell.entity.Sell;
import com.dd.admin.business.sell.service.SellService;
import com.dd.admin.business.sellDetail.entity.SellDetail;
import com.dd.admin.business.sellDetail.service.SellDetailService;
import com.dd.admin.business.sellPay.entity.Sellpay;
import com.dd.admin.business.sellPay.service.SellpayService;
import com.dd.admin.common.exception.ApiException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.math.BigDecimal;import static com.dd.admin.business.pay.enmus.CashierExceptionEnum.CARDNO_ALREADY_EXIST;@Service
public class SellDetailBuildCard implements AddSellDetailService {@Autowiredprivate CardService cardService;@Autowiredprivate MemberCardService memberCardService;@Autowiredprivate SellDetailService sellDetailService;@Autowiredprivate SellpayService sellpayService;@Autowiredprivate SellService sellService;@Overridepublic void addSellDetail(Sell sell, BaseSell sellDto) {//转换数据BuildCardSell buildCardSell = (BuildCardSell) sellDto;// 1 获取开卡金额 等信息 先开卡String cardId = buildCardSell.getBuildCardForm().getCardId();//获取需要的开卡信息Card card = cardService.getById(cardId);//开卡MemberCard memberCard = buildMemberCard(sell, buildCardSell.getBuildCardForm(), card);//2生成销售细单SellDetail sellDetail = addSellDetail(sell,buildCardSell,memberCard);//添加支付方式sellpayService.addSellPayList(buildCardSell.getSellPayList(),sell.getSellId());//4因为是开卡还要设置额外信息Sell extraSellInfo = new Sell();extraSellInfo.setSellId(sell.getSellId());//设置会员信息extraSellInfo.setMemberId(buildCardSell.getMemberId());extraSellInfo.setMemberName(buildCardSell.getMemberName());//设置订单的卡信息extraSellInfo.setMemberCardId(memberCard.getMemberCardId());//设置订单的卡余额extraSellInfo.setMemberCardBeforeAmount(BigDecimal.ZERO);extraSellInfo.setMemberCardBeforeGiveAmount(BigDecimal.ZERO);extraSellInfo.setMemberCardAfterAmount(memberCard.getAmount());extraSellInfo.setMemberCardAfterGiveAmount(memberCard.getGiveAmount());sellService.updateById(extraSellInfo);}MemberCard buildMemberCard(Sell sell, BuildCardForm buildCardForm, Card card){//设置卡的基本和余额信息MemberCard memberCard = new MemberCard();memberCard.setMemberId(sell.getMemberId());memberCard.setCardId(card.getCardId());memberCard.setCardName(card.getCardName());String cardNo = buildCardForm.getCardNo();MemberCardVo membercardVo = memberCardService.selectOneByCardNo(cardNo);if(membercardVo!=null){throw new ApiException(CARDNO_ALREADY_EXIST);}memberCard.setCardNo(buildCardForm.getCardNo());memberCard.setAmount(buildCardForm.getCardAmount());memberCard.setBuildCardAmount(buildCardForm.getCardAmount());memberCard.setGiveAmount(buildCardForm.getGiveAmount());//获取订单的卡折扣信息 设置进会员卡中memberCard.setDiscount(card.getCardDiscount());//设置该卡的提成金额memberCard.setPushMoney(card.getCardPushPercent());memberCardService.save(memberCard);return memberCard;}SellDetail addSellDetail(Sell sell,BuildCardSell buildCardSell,MemberCard membercard){BuildCardForm buildCardForm = buildCardSell.getBuildCardForm();SellDetail sellDetail = new SellDetail();//3设置订单id 订单类型 订单状态sellDetail.setSellId(sell.getSellId());sellDetail.setSellType(sell.getSellType());sellDetail.setMemberId(sell.getMemberId());//设置商品信息sellDetail.setCardId(buildCardForm.getCardId());sellDetail.setCardName(buildCardForm.getCardName());sellDetail.setAmount(buildCardForm.getCardAmount());sellDetail.setGiveAmount(buildCardForm.getGiveAmount());sellDetail.setRealAmount(sell.getRealAmount());//设置会员信息sellDetail.setMemberCardId(membercard.getMemberCardId());//开卡后卡金和赠送金sellDetail.setAmount(membercard.getAmount());sellDetail.setGiveAmount(membercard.getGiveAmount());//保存销售细单sellDetailService.save(sellDetail);return sellDetail;}}
后续我们需要完成收银台的选择会员卡支付
订单管理功能
代码地址
https://gitee.com/ddeatrr/memberShop
相关文章:
springboot vue 开源 会员收银系统 (7) 收银台的完善 新增开卡 结算
前言 完整版演示 开发版演示 在前面的开发中,我们成功完成了商品分类和商品信息的搭建,开发了收银台基础。现在,我们将进一步完善收银台的功能,添加开卡和结算功能,并在后台实现会员卡的创建和订单保存。同时ÿ…...
虚拟现实环境下的远程教育和智能评估系统(十三)
管理/教师端前端工作汇总education-admin: 首先是登录注册页面的展示 管理员 首页 管理员登录后的首页如下图所示 管理员拥有所有的权限 课程管理 1、可以查看、修改、增添、删除课程列表内容 2、可以对课程资源进行操作 3、可以对课程的类别信息进行管理&…...
深入了解软件设计模式:创新应用与优化代码结构
前言 在软件开发中,设计模式被广泛应用,通常分为三大类:创建型、结构型和行为型。这些模式经过时间验证,在解决特定问题和优化代码结构方面发挥了重要作用。本文将详细介绍每一类设计模式,并通过具体实例展示它们的应…...
android studio 模拟器文件查找
android studio 模拟器文件查找 使用安卓模拟器下载文件后通常无法在系统硬盘上找到下载的文件,安卓 studio studio 其实提供了文件浏览工具,找到后可以直接使用 Android studio 打开 打开 Android studioview 菜单view > Tool Windows > Device…...
【科普】半导体制造过程的步骤、技术、流程
在这篇文章中,我们将学习基本的半导体制造过程。为了将晶圆转化为半导体芯片,它需要经历一系列复杂的制造过程,包括氧化、光刻、刻蚀、沉积、离子注入、金属布线、电气检测和封装等。 基本的半导体制造过程 1.晶圆(Wafer…...
c89、c99、c11
C99 标准开始引入了 // 单行注释。在此之前,C语言只支持 /* ... */ 多行注释。 具体说明: // 单行注释:在C99标准(ISO/IEC 9899:1999)引入之前,C语言中没有单行注释。C99标准借鉴了C的注释风格࿰…...
【网络安全的神秘世界】已解决burpsuite报错Failed to start proxy service on 127.0.0.1:8080
🌝博客主页:泥菩萨 💖专栏:Linux探索之旅 | 网络安全的神秘世界 | 专接本 | 每天学会一个渗透测试工具 解决burpsuite无法在 127.0.0.1:8080 上启动代理服务端口被占用以及抓不到本地包的问题 Burpsuite无法启动proxy…...
【C#】使用数字和时间方法ToString()格式化输出字符串显示
在C#编程项目开发中,几乎所有对象都有格式化字符串方法,其中常见的是数字和时间的格式化输出多少不一样,按实际需要而定吧,现记录如下,以后会用得上。 文章目录 数字格式化时间格式化 数字格式化 例如,保留…...
Mac系统主机名变为bogon的解决方案
如题 在使用Mac操作系统时,您可能会遇到一个有趣且略显困扰的问题:终端中显示的主机名突然变成了“bogon”。这不仅让人困惑,还可能给日常操作带来不便。本文旨在提供一种简便的解决方法,帮助您将主机名恢复为正常状态。 什么是…...
行列式和矩阵的区别
目录 一、行列式 1. 行列式的定义 2. (全)排列 3. 逆序数 二、矩阵 1. 矩阵的定义 三、行列式和矩阵的区别 四、参考书目 一、行列式 1. 行列式的定义 2. (全)排列 3. 逆序数 二、矩阵 1. 矩阵的定义 三、行列式和矩阵的区别 四、参考书目 同济大学数学系. 工程数学…...
MATLAB复习
MATLAB常用的标点符号 空格 变量分隔符 矩阵一行中各元素间的分隔符 程序语句关键词分隔符 逗号,分隔显示计算结果的各语句 变量分隔符 矩阵中一行各元素的分隔符点号.数值中的小数点 结构数组的域访问符分号;分隔不想显示计算结果的各语句 矩阵行与行的…...
Android11 动态权限申请
1、单个权限检查及申请 private void checkSinglePermission(){// 在需要的地方,如Activity中if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_PHONE_STATE)! PackageManager.PERMISSION_GRANTED) {ActivityCompat.requestPermissions(this,…...
线性卷积(相关)和圆周卷积(相关)以及FFT之间的关系(AEC举例)
时域自适应滤波算法中的线性卷积和线性相关运算量较大,导致计算复杂度升高,我们更愿意把这两个信号变换到频域,通过频域相乘的方式来取代时域复杂度相当高的卷积或相关运算。 预备知识:线性卷积(相关)和圆…...
AMD平台,5600X+6650XT,虚拟机安装macOS 14(2024年6月)
AMD平台安装macOS 14的麻烦,要比Intel平台多的多,由于macOS从13开始,对CPU寄存器的读取进行了改变,导致AMD平台只要安装完macOS 13及以后版本,开机后就报五国语言错误,不断重启。改vmx文件,被证…...
Spring源码之手写DI
Spring源码之手写DI 我们来回顾一下前面手写IOC的内容。 一、DI介绍 DI(Dependency injection)依赖注入。对象之间的依赖由容器在运行期决定,即容器动态的将某个依赖注入到对象之中。说直白点就是给Bean对象的成员变量赋值。 在这里我们就需要明白几个问题。 1.…...
从零入手人工智能(5)—— 决策树
1.前言 在上一篇文章《从零入手人工智能(4)—— 逻辑回归》中讲述了逻辑回归这个分类算法,今天我们的主角是决策树。决策树和逻辑回归这两种算法都属于分类算法,以下是决策树和逻辑回归的相同点: 分类任务࿱…...
go语言:两协程并发交替打印数字和字母(代码逐行注释)
要求: 并发两协程交替打印数字和字母。一个协程打印数字,一个协程打印字母。 输出: 12AB34CD56EF78GH910IJ1112KL1314MN1516OP1718QR1920ST2122UV2324WX2526YZ2728 思路: 两个 channel 控制两个协程进行交替打印。sync.WaitG…...
TWM论文阅读笔记
这是ICLR2023的一篇world model论文,用transformer来做世界模型的sequence prediction。文章贡献是transformer-based world model(不同于以往的如transdreamer的world model,本文的transformer-based world model在inference 的时候可以丢掉…...
探索ChatTTS项目:高效的文字转语音解决方案
文章目录 📖 介绍 📖📒 ChatTTS 📒📝 项目介绍📝 项目亮点📝 UI 🎈 项目地址 🎈 📖 介绍 📖 在AI技术迅速发展的今天,文本到语音&…...
[Django学习]Q对象实现多字段模糊搜索
一、应用场景 假设我们现在有一个客房系统,前端界面上展示出来了所有客房的所有信息。用户通过客房的价格、面积、人数等对客房进行模糊搜索,如检索出价格在50到100元之间的客房,同时检索面积在20平方米到30平方米之间的客房,此时后端可以借助…...
基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容
基于 UniApp + WebSocket实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...
定时器任务——若依源码分析
分析util包下面的工具类schedule utils: ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类,封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz,先构建任务的 JobD…...
Spring Boot面试题精选汇总
🤟致敬读者 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉 📘博主相关 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息 文章目录 Spring Boot面试题精选汇总⚙️ **一、核心概…...
QT: `long long` 类型转换为 `QString` 2025.6.5
在 Qt 中,将 long long 类型转换为 QString 可以通过以下两种常用方法实现: 方法 1:使用 QString::number() 直接调用 QString 的静态方法 number(),将数值转换为字符串: long long value 1234567890123456789LL; …...
ArcGIS Pro制作水平横向图例+多级标注
今天介绍下载ArcGIS Pro中如何设置水平横向图例。 之前我们介绍了ArcGIS的横向图例制作:ArcGIS横向、多列图例、顺序重排、符号居中、批量更改图例符号等等(ArcGIS出图图例8大技巧),那这次我们看看ArcGIS Pro如何更加快捷的操作。…...
零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)
本期内容并不是很难,相信大家会学的很愉快,当然对于有后端基础的朋友来说,本期内容更加容易了解,当然没有基础的也别担心,本期内容会详细解释有关内容 本期用到的软件:yakit(因为经过之前好多期…...
Java 二维码
Java 二维码 **技术:**谷歌 ZXing 实现 首先添加依赖 <!-- 二维码依赖 --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.5.1</version></dependency><de…...
浪潮交换机配置track检测实现高速公路收费网络主备切换NQA
浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...
七、数据库的完整性
七、数据库的完整性 主要内容 7.1 数据库的完整性概述 7.2 实体完整性 7.3 参照完整性 7.4 用户定义的完整性 7.5 触发器 7.6 SQL Server中数据库完整性的实现 7.7 小结 7.1 数据库的完整性概述 数据库完整性的含义 正确性 指数据的合法性 有效性 指数据是否属于所定…...
