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 随后进行地址转换
然后参考我们之前写的

相关文章
|
16天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
93 1
|
1天前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
10天前
|
存储 安全 Java
打造智能合同管理系统:SpringBoot与电子签章的完美融合
【10月更文挑战第7天】 在数字化转型的浪潮中,电子合同管理系统因其高效、环保和安全的特点,正逐渐成为企业合同管理的新宠。本文将分享如何利用SpringBoot框架实现一个集电子文件签字与合同管理于一体的智能系统,探索技术如何助力合同管理的现代化。
38 4
|
10天前
|
前端开发 Java Apache
SpringBoot实现电子文件签字+合同系统!
【10月更文挑战第15天】 在现代企业运营中,合同管理和电子文件签字成为了日常活动中不可或缺的一部分。随着技术的发展,电子合同系统因其高效性、安全性和环保性,逐渐取代了传统的纸质合同。本文将详细介绍如何使用SpringBoot框架实现一个电子文件签字和合同管理系统。
27 1
|
13天前
|
文字识别 安全 Java
SpringBoot3.x和OCR构建车牌识别系统
本文介绍了一个基于Java SpringBoot3.x框架的车牌识别系统,详细阐述了系统的设计目标、需求分析及其实现过程。利用Tesseract OCR库和OpenCV库,实现了车牌图片的识别与处理,确保系统的高准确性和稳定性。文中还提供了具体的代码示例,展示了如何构建和优化车牌识别服务,以及如何处理特殊和异常车牌。通过实际应用案例,帮助读者理解和应用这一解决方案。
|
17天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第8天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建并配置 Spring Boot 项目,实现后端 API 和安全配置。接着,使用 Ant Design Pro Vue 脚手架创建前端项目,配置动态路由和菜单,并创建相应的页面组件。最后,通过具体实践心得,分享了版本兼容性、安全性、性能调优等注意事项,帮助读者快速搭建高效且易维护的应用框架。
23 3
|
JavaScript 算法 Java
springboot vue二手交易市场毕设源码(毕设)
springboot vue二手交易市场毕设源码
362 0
springboot vue二手交易市场毕设源码(毕设)
|
2月前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的服装商城管理系统
基于Java+Springboot+Vue开发的服装商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的服装商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
116 2
基于Java+Springboot+Vue开发的服装商城管理系统
|
2月前
|
前端开发 JavaScript Java
SpringBoot项目部署打包好的React、Vue项目刷新报错404
本文讨论了在SpringBoot项目中部署React或Vue打包好的前端项目时,刷新页面导致404错误的问题,并提供了两种解决方案:一是在SpringBoot启动类中配置错误页面重定向到index.html,二是将前端路由改为hash模式以避免刷新问题。
167 1
|
2月前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的大学竞赛报名管理系统
基于Java+Springboot+Vue开发的大学竞赛报名管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的大学竞赛报名管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
165 3
基于Java+Springboot+Vue开发的大学竞赛报名管理系统