springboot vue 开源 会员收银系统 (5) 分类及商品模块开发

简介: 业务表存图片id 随后进行地址转换

前面我们对会员系统 门店模块开发的开发 完成了门店的基础管理 并与会员相关联
下面我们将开发门店的分类及商品管理 我们分析以下几个重点

分类可以随时禁用不用单独下架某个商品便于管理
商品添加应该有图片上传
商品设置会员价和散客价便于营销
商品应该参与库存管理 不参与管理的设置字段标明(相关字段加锁)
商品应该有上下架功能
商品加上提成相关设置 便于计算工资
商品加上逻辑删除功能 防止后续统计无法取到原始值
商品等敏感进行修改时应该进行记录防止恶意操作
下面开始字段设计

分类表

CREATE TABLE business_category (
CATEGORY_ID varchar(32) NOT NULL COMMENT '分类id',
CATEGORY_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',
CATEGORY_STATUS tinyint(2) DEFAULT '0' COMMENT '0正常 1禁用',
SHOP_ID varchar(32) DEFAULT NULL COMMENT '门店id',
SHOP_NAME varchar(255) DEFAULT NULL COMMENT '门店名',
PRIMARY KEY (CATEGORY_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='分类';
1
2
3
4
5
6
7
8
9
10
11
12
13
14
商品表

CREATE TABLE business_product (
PRODUCT_ID varchar(32) NOT NULL COMMENT '商品id',
CATEGORY_ID varchar(32) DEFAULT NULL COMMENT '分类id',
CATEGORY_NAME varchar(255) DEFAULT NULL COMMENT '分类名',
PRODUCT_NAME varchar(255) DEFAULT NULL COMMENT '商品名',
PRODUCT_AMOUNT decimal(10,2) DEFAULT NULL COMMENT '商品金额',
PRODUCT_MEMBER_AMOUNT decimal(10,2) DEFAULT NULL COMMENT '商品会员金额',
PRODUCT_IMAGE varchar(255) DEFAULT NULL COMMENT '商品图片',
PRODUCT_COUNT bigint(20) DEFAULT NULL COMMENT '库存数量',
PUSH_AMOUNT decimal(10,2) DEFAULT NULL COMMENT '提成金额',
PUSH_PERCENT varchar(255) DEFAULT NULL COMMENT '提成比例',
PRODUCT_STATUS tinyint(2) DEFAULT '0' COMMENT '0正常 1下架',
VERSION bigint(10) DEFAULT '0' COMMENT '乐观锁字段',
DELETED tinyint(2) DEFAULT '0' COMMENT '0正常 1删除',
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 (PRODUCT_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='商品';

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
代码开发
在开发之前我们顺带完成文件上传功能
关键代码

public FileVo uploadFile(MultipartFile file, String fileSavePath) {
//需要返回的对象
FileVo fileVo = new FileVo();

    //生成文件的唯一id
    String fileId = IdWorker.get32UUID();
    fileVo.setFileId(fileId);

    //获取文件后缀
    String fileSuffix = ToolUtil.getFileSuffix(file.getOriginalFilename());
    fileVo.setFileSuffix(fileSuffix);

    //获取文件原始名称
    String originalFilename = file.getOriginalFilename();
    fileVo.setOriginalFilename(originalFilename);

    //生成文件的最终名称
    String finalName = fileId + "." + ToolUtil.getFileSuffix(originalFilename);
    fileVo.setFinalName(finalName);
    fileVo.setFileSavePath(fileSavePath + finalName);

    String sysUploadPath = getSysUploadPath();

    String newFileSavePath = "";

    //判断有没有结尾符,没有得加上
    if (!fileSavePath.endsWith(java.io.File.separator)) {
        newFileSavePath = fileSavePath + java.io.File.separator;
    }

    try {
        java.io.File filepath = new java.io.File(sysUploadPath + newFileSavePath );
        //该目录不存在 则创建
        if (!filepath.exists()) {
            boolean mkdirs = filepath.mkdirs();
        }

        //保存文件到指定目录
        java.io.File newFile = new java.io.File(sysUploadPath + newFileSavePath + finalName);
        file.transferTo(newFile);

        File fileInfo = new File();
        //保存文件信息
        fileInfo.setFileId(fileId);
        fileInfo.setFileName(originalFilename);
        fileInfo.setFileSuffix(fileSuffix);

        fileInfo.setFilePath("/upload/" + fileSavePath + "/" + finalName);

        fileVo.setFileSavePath(fileInfo.getFilePath());
        fileInfo.setFinalName(finalName);

        //计算文件大小kb
        long kb = new BigDecimal(file.getSize())
                .divide(BigDecimal.valueOf(1024))
                .setScale(0, BigDecimal.ROUND_HALF_UP).longValue();
        fileInfo.setFileSizeKb(kb);
        fileInfo.setFileSysPath(newFile.getAbsolutePath());

        save(fileInfo);
    } catch (Exception e) {
        log.error("上传文件错误!", e);
        throw new ApiException("上传文件错误!");
    }
    return fileVo;
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
其实很简单

提前维护好地址 设置保存路径
将上传后的图片地址保存在数据库中
业务表存图片id 随后进行地址转换
然后参考我们之前写的

相关文章
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的项目管理系统
本文探讨项目管理系统在现代企业中的应用与实现,分析其研究背景、意义及现状,阐述基于SSM、Java、MySQL和Vue等技术构建系统的关键方法,展现其在提升管理效率、协同水平与风险管控方面的价值。
|
3月前
|
监控 安全 JavaScript
2025基于springboot的校车预定全流程管理系统
针对传统校车管理效率低、信息不透明等问题,本研究设计并实现了一套校车预定全流程管理系统。系统采用Spring Boot、Java、Vue和MySQL等技术,实现校车信息管理、在线预定、实时监控等功能,提升学校管理效率,保障学生出行安全,推动教育信息化发展。
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的高校运动会系统
本系统基于Spring Boot、Vue与MySQL,实现高校运动会报名、赛程安排及成绩管理的全流程信息化,提升组织效率,杜绝信息错漏与冒名顶替,推动体育赛事智能化发展。
|
3月前
|
JavaScript 安全 Java
基于springboot的大学生兼职系统
本课题针对大学生兼职信息不对称、权益难保障等问题,研究基于Spring Boot、Vue、MySQL等技术的兼职系统,旨在构建安全、高效、功能完善的平台,提升大学生就业竞争力与兼职质量。
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的美食城服务管理系统
本系统基于Spring Boot、Java、Vue和MySQL技术,构建集消费者服务、商家管理与后台监管于一体的美食城综合管理平台,提升运营效率与用户体验。
|
3月前
|
Java 关系型数据库 MySQL
基于springboot的网咖网吧管理系统
本文探讨了基于Java、MySQL和SpringBoot的网吧管理系统的设计与实现。随着信息化发展,传统管理方式难以满足需求,而该系统通过先进技术提升管理效率、保障数据安全、降低运营成本,具有重要意义。
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的摄影师分享交流社区系统
本系统基于Spring Boot与Vue构建摄影师分享交流平台,旨在打造专业社区,支持作品展示、技术交流与合作互动。采用Java、MySQL等成熟技术,提升摄影爱好者创作水平,推动行业发展。
|
3月前
|
JavaScript 搜索推荐 Java
基于SpringBoot的社区老年食堂系统
针对老龄化社会饮食难题,智慧社区老年食堂系统应运而生。融合Spring Boot、Vue、Java与MySQL技术,实现餐饮服务智能化、个性化,提升老年人生活质量与幸福感,推动社区养老服务升级。
|
3月前
|
JavaScript 搜索推荐 Java
基于springboot的民宿预定管理系统
本研究针对民宿市场管理效率低、信息化程度不足等问题,设计并实现基于Spring Boot、Vue和MySQL的民宿预订管理系统。系统提升预订效率与用户体验,助力行业数字化转型。