“打造智能售货机系统,基于ruoyi微服务版本开源项目“

目录

# 开篇

售货机术语

1. 表设计说明

2. 页面展示

2.1 区域管理页面

2.2 合作商管理页面

2.3 点位管理页面

3. 建表资源

3.1 创建表的 SQL 语句(包含字段备注)

1. Region 表

2. Node 表

3. Partner 表

4. 创建 tb_vending_machine 表的 SQL 语句

3.2 插入数据的 SQL 语句(无变化)

1. 插入 Region 数据

2. 插入 Partner 数据

3. 插入 Node 数据

4. 插入 VendingMachine数据

3.3 查询数据的 SQL 语句(无变化)

1. 查询所有 Region 数据

2. 查询所有 Partner 数据

3. 查询所有 Node 数据及其相关的 Region 和 Partner 信息

4. AI智能化编程

4.1 下载教程


上篇:“打造智能售货机系统,基于ruoyi微服务版本生成基础代码“-CSDN博客

# 开篇

        在现代社会中,智能售货机逐渐成为人们日常生活中不可或缺的一部分。为了更好地练手微服务架构,本章将基于RuoYi-Cloud微服务版本,快速搭建一个智能售货机系统。本章的重点是智能售货机系统下的点位管理模块,包含页面演示和建表资源。

注:系统基于ruoyi-cloud微服务版本,从前端到后端再到AI智能化应用;

售货机术语

为了更好地理解和开发智能售货机系统,首先我们需要了解一些相关术语:

  1. 区域管理

    为了更高效地进行经营管理,公司将运营范围划分为若干个逻辑区域。这些区域可以根据地理位置、客户群体等因素进行划分,有助于企业在不同区域内制定更有针对性的经营策略。

  2. 点位选择

    点位指的是智能售货机的具体放置位置。选择合适的点位是售货机运营成功的关键之一。理想的点位应该具备较高的人流量、便利的交通条件以及良好的安全性。

  3. 未来售货机功能

    智能售货机就像一个自动的小店,里面摆满了各种商品。随着技术的发展,未来的智能售货机将具备更多智能化功能,如自动补货、实时库存监控、个性化推荐等,提升用户体验和运营效率。

  4. 货道设计

    货道设计指的是售货机内部的货道布局,可以想象成超市里的那种货架。合理的货道设计可以提高售货机的存储效率和取货便捷性。

通过本章的学习,我们将了解如何基于RuoYi微服务版本,快速搭建一个智能售货机系统,并掌握点位管理模块的实现方法。帮助我们在实践中能够深入理解微服务架构的优势,并积累宝贵的开发经验。

接下来,本编将详细介绍智能售货机系统的点位管理模块,包括页面演示和建表资源的设计与实现。

1. 表设计说明

这张图片展示了一个智能售货机系统中的点位管理模块的结构图。图中包含区域管理、点位管理、合作商管理和设备管理四个部分,每个部分都有对应的数据库表和行为。下面是对这张图的详细分析:

  1. 区域管理

    表名:tb_region

    字段:

    • id:区域的唯一标识
    • region_name:区域名称
    • 其他区域相关的基础数据字段

    区域管理主要负责对公司运营范围内的逻辑区域进行管理,一个区域下可以包含多个点位。

  2. 点位管理

    表名:tb_node

    字段:

    • id:点位的唯一标识
    • node_name:点位名称
    • 其他点位相关的基础数据字段
    • region_id:关联的区域ID
    • partner_id:关联的合作商ID

    点位管理主要负责管理售货机的具体放置位置,一个区域下可以包含多个点位,一个合作商下也可以包含多个点位。

  3. 合作商管理

    表名:tb_partner

    字段:

    • id:合作商的唯一标识
    • partner_name:合作商名称
    • 其他合作商相关的基础数据字段

    合作商管理主要负责管理与公司合作的各种合作商,一个合作商下可以包含多个点位和设备。

  4. 设备管理

    表名:tb_vending_machine

    字段:

    • id:设备的唯一标识
    • inner_code:设备内部代码
    • 其他设备相关的基础数据字段
    • node_id:关联的点位ID
    • region_id:关联的区域ID
    • partner_id:关联的合作商ID

    设备管理主要负责对智能售货机设备的管理,一个区域下可以包含多个设备,一个合作商下可以包含多个设备,一个点位下也可以包含多个设备。

  • 关系

    区域管理通过region_id与点位管理和设备管理建立关联。

    点位管理通过node_id与设备管理建立关联,通过partner_id与合作商管理建立关联。

    合作商管理通过partner_id与点位管理和设备管理建立关联。

    这个结构图展示了智能售货机系统中如何通过模块化管理区域、点位、合作商和设备,使得整个系统的管理更加高效和清晰。

2. 页面展示

2.1 区域管理页面

2.2 合作商管理页面

2.3 点位管理页面

3. 建表资源

3.1 创建表的 SQL 语句(包含字段备注)

1. Region 表
CREATE TABLE tb_region (
    id INT AUTO_INCREMENT PRIMARY KEY COMMENT '区域 ID',
    region_name VARCHAR(255) NOT NULL COMMENT '区域名称',
    create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
    create_by VARCHAR(64) COMMENT '创建人',
    update_by VARCHAR(64) COMMENT '修改人',
    remark TEXT COMMENT '备注'
) COMMENT '区域表';
2. Node 表
CREATE TABLE tb_node (
    id INT AUTO_INCREMENT PRIMARY KEY COMMENT '点位 ID',
    node_name VARCHAR(255) NOT NULL COMMENT '点位名称',
    address VARCHAR(255) COMMENT '详细地址',
    business_type VARCHAR(64) COMMENT '业务类型',
    region_id INT COMMENT '区域 ID',
    partner_id INT COMMENT '合作商 ID',
    create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
    create_by VARCHAR(64) COMMENT '创建人',
    update_by VARCHAR(64) COMMENT '修改人',
    remark TEXT COMMENT '备注',
    FOREIGN KEY (region_id) REFERENCES tb_region(id),
    FOREIGN KEY (partner_id) REFERENCES tb_partner(id)
) COMMENT '点位表';
3. Partner 表
CREATE TABLE tb_partner (
    id INT AUTO_INCREMENT PRIMARY KEY COMMENT '合作商 ID',
    partner_name VARCHAR(255) NOT NULL COMMENT '合作商名称',
    contact_person VARCHAR(64) COMMENT '联系人',
    contact_phone VARCHAR(15) COMMENT '联系电话',
    profit_ratio INT COMMENT '分成比例',
    account VARCHAR(64) COMMENT '账号',
    password VARCHAR(64) COMMENT '密码',
    create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
    create_by VARCHAR(64) COMMENT '创建人',
    update_by VARCHAR(64) COMMENT '修改人',
    remark TEXT COMMENT '备注'
) COMMENT '合作商表';
4. 创建 tb_vending_machine 表的 SQL 语句
CREATE TABLE tb_vending_machine (
    id INT AUTO_INCREMENT PRIMARY KEY COMMENT '主键 ID',
    inner_code BIGINT NOT NULL COMMENT '设备编号',
    channel_max_capacity INT COMMENT '设备容盘',
    node_id INT COMMENT '点位 ID',
    addr VARCHAR(100) COMMENT '详细地址',
    last_supply_time DATETIME COMMENT '上次补货时间',
    business_type INT COMMENT '商业类型',
    region_id INT COMMENT '区域 ID',
    partner_id INT COMMENT '合作商 ID',
    vm_type_id INT COMMENT '设备型号',
    vm_status INT COMMENT '设备状态,0:未投放; 1:运营; 2:维修',
    running_status VARCHAR(100) COMMENT '运行状态',
    longitude DOUBLE COMMENT '经度',
    latitude DOUBLE COMMENT '纬度',
    client_id VARCHAR(50) COMMENT '客户端连接 ID,用于 EMQ 认证',
    policy_id BIGINT COMMENT '策略 ID',
    create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
    FOREIGN KEY (node_id) REFERENCES tb_node(id),
    FOREIGN KEY (region_id) REFERENCES tb_region(id),
    FOREIGN KEY (partner_id) REFERENCES tb_partner(id)
) COMMENT '设备表';

3.2 插入数据的 SQL 语句(无变化)

1. 插入 Region 数据
INSERT INTO tb_region (region_name, create_by, remark)
VALUES 
('华东', 'admin', '东部地区'),
('华南', 'admin', '南部地区');
2. 插入 Partner 数据
INSERT INTO tb_partner (partner_name, contact_person, contact_phone, profit_ratio, account, password, create_by, remark)
VALUES 
('合作商A', '张三', '12345678901', 20, 'accountA', 'passwordA', 'admin', '优质合作商'),
('合作商B', '李四', '19876543210', 15, 'accountB', 'passwordB', 'admin', '重要合作商');
3. 插入 Node 数据
INSERT INTO tb_node (node_name, address, business_type, region_id, partner_id, create_by, remark)
VALUES 
('节点1', '地址1', '旅游区', 1, 1, 'admin', '优质点位'),
('节点2', '地址2', '商场写字楼', 2, 2, 'admin', '主要点位');
4. 插入 VendingMachine数据
INSERT INTO tb_vending_machine (
    inner_code, channel_max_capacity, node_id, addr, last_supply_time, business_type, 
    region_id, partner_id, vm_type_id, vm_status, running_status, longitude, latitude, 
    client_id, policy_id, create_time, update_time
)
VALUES
-- 设备1,关联 node_id 1
(1000001, 100, 1, '地址1', '2024-06-01 12:00:00', 1, 1, 1, 1, 1, '正常运行', 116.391, 39.907, 'client_1', 1, '2024-06-01 12:00:00', '2024-06-01 12:00:00'),
-- 设备2,关联 node_id 1
(1000002, 100, 1, '地址1', '2024-06-02 13:00:00', 1, 1, 1, 1, 1, '正常运行', 116.392, 39.908, 'client_2', 1, '2024-06-02 13:00:00', '2024-06-02 13:00:00'),
-- 设备3,关联 node_id 1
(1000003, 100, 1, '地址1', '2024-06-03 14:00:00', 1, 1, 1, 1, 1, '正常运行', 116.393, 39.909, 'client_3', 1, '2024-06-03 14:00:00', '2024-06-03 14:00:00'),
-- 设备4,关联 node_id 1
(1000004, 100, 1, '地址1', '2024-06-04 15:00:00', 1, 1, 1, 1, 1, '正常运行', 116.394, 39.910, 'client_4', 1, '2024-06-04 15:00:00', '2024-06-04 15:00:00'),
-- 设备5,关联 node_id 1
(1000005, 100, 1, '地址1', '2024-06-05 16:00:00', 1, 1, 1, 1, 1, '正常运行', 116.395, 39.911, 'client_5', 1, '2024-06-05 16:00:00', '2024-06-05 16:00:00'),
-- 设备6,关联 node_id 2
(1000006, 100, 2, '地址2', '2024-06-06 17:00:00', 2, 2, 2, 2, 1, '正常运行', 117.391, 38.907, 'client_6', 1, '2024-06-06 17:00:00', '2024-06-06 17:00:00'),
-- 设备7,关联 node_id 2
(1000007, 100, 2, '地址2', '2024-06-07 18:00:00', 2, 2, 2, 2, 1, '正常运行', 117.392, 38.908, 'client_7', 1, '2024-06-07 18:00:00', '2024-06-07 18:00:00'),
-- 设备8,关联 node_id 2
(1000008, 100, 2, '地址2', '2024-06-08 19:00:00', 2, 2, 2, 2, 1, '正常运行', 117.393, 38.909, 'client_8', 1, '2024-06-08 19:00:00', '2024-06-08 19:00:00'),
-- 设备9,关联 node_id 2
(1000009, 100, 2, '地址2', '2024-06-09 20:00:00', 2, 2, 2, 2, 1, '正常运行', 117.394, 38.910, 'client_9', 1, '2024-06-09 20:00:00', '2024-06-09 20:00:00'),
-- 设备10,关联 node_id 2
(1000010, 100, 2, '地址2', '2024-06-10 21:00:00', 2, 2, 2, 2, 1, '正常运行', 117.395, 38.911, 'client_10', 1, '2024-06-10 21:00:00', '2024-06-10 21:00:00');

3.3 查询数据的 SQL 语句(无变化)

1. 查询所有 Region 数据
SELECT * FROM tb_region;
2. 查询所有 Partner 数据
SELECT * FROM tb_partner;
3. 查询所有 Node 数据及其相关的 Region 和 Partner 信息
SELECT 
    n.id AS node_id,
    n.node_name,
    n.address,
    n.business_type,
    r.region_name,
    p.partner_name,
    n.create_time,
    n.update_time,
    n.create_by,
    n.update_by,
    n.remark
FROM 
    tb_node n
JOIN 
    tb_region r ON n.region_id = r.id
JOIN 
    tb_partner p ON n.partner_id = p.id;

4. AI智能化编程

如图中使用:输入代码表述,使用ai智能化编程;

4.1 下载教程

idea中搜索tongyi;

下载后使用阿里云账号登录使用; 

vscode下载安装:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/730949.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024会展行业发展趋势预测

在当今这个数字化浪潮汹涌的时代,会展行业也迎来了自己的变革时刻。 根据《2023中国会展主办机构数字化调研报告》,我们可以清晰地看到几个显著的趋势: 首先,数字化转型已经不再是一道选择题,而是必答题。 超过90%的…

伦敦银趋势线的有效性怎么验证?

怎么才能画出一根能发挥作用的趋势线呢?这是很多投资者追求的目标。其实要趋势线能发挥作用,我们在画它的时候就要进行一些验证,将通过了验证的趋势线保留下来,那些没通过的就删除,这样得到能发挥作用的趋势线的概率就…

学校校园考场电子钟,同步授时,助力考场公平公正-讯鹏科技

随着教育技术的不断发展,学校对于考场管理的需求也日益提高。传统的考场时钟往往存在时间误差、维护不便等问题,这在一定程度上影响了考试的公平性和公正性。为了解决这些问题,越来越多的学校开始引入考场电子钟,通过同步授时技术…

编译原理-各章典型题型+思路求解

第2章文法和语言习题 基础知识: 思路: 基础知识: 思路: 基础知识: 编译原理之 短语&直接短语&句柄 定义与区分_编译原理短语,直接短语,句柄-CSDN博客 思路: 题目: 基础解释&#xff1a…

路由器的Wi-Fi性能是否限制了你的网速?这里有你想要的答案

​你的无线网络速度阻碍了你吗?信不信由你,升级到超快的互联网计划可能不值得。以下是如何判断路由器的Wi-Fi速度是否阻碍了你,以及你能做些什么。 如何测试你的Wi-Fi速度 比较你的有线速度和无线速度可以表明你的路由器是否阻碍了你。虽然很多人认为“Wi-Fi”和“互联网”…

python pyautogui实现图片识别点击失败后重试

安装库 pip install Pillow pip install opencv-python confidence作用 confidence 参数是用于指定图像匹配的信度(或置信度)的,它表示图像匹配的准确程度。这个参数的值在 0 到 1 之间,数值越高表示匹配的要求越严格。 具体来…

PCB设计中的via孔和pad孔

原文出自微信公众号【小小的电子之路】 在PCB设计过程中,经常会提到via孔和pad孔,下面就简单介绍一下二者的区别。 via称为过孔,主要起到电气连接的作用,用于网络在不同层的导线之间的连接。PCB设计中一般做盖油处理。 via孔 vi…

【SkiaSharp绘图08】SKPaint方法:自动换行、是否乱码、字符偏移、边界、截距、文本轮廓、测量文本

文章目录 SKPaint方法BreakText 计算指定宽度内可绘制的字符个数ContainsGlyphs字体是否包含文本字符(是否会乱码)GetGlyphOffsets 字符偏移量GetGlyphPositions 偏移坐标GetGlyphWidths 每个字符的宽度与边界GetHorizontalTextIntercepts 轮廓截距GetPositionedTextIntercepts…

浅谈配置元件之LDAP默认请求

浅谈配置元件之LDAP默认请求 在进行LDAP(轻量级目录访问协议)相关测试时,JMeter提供了“LDAP 默认请求”配置元件来帮助用户便捷地设置LDAP查询的基本参数。本文介绍如何在JMeter中配置和使用“LDAP 默认请求”元件的指南。 1. 简介 “LDA…

海外社媒网站抓取经验总结:如何更高效实现网页抓取?

有效的网络抓取需要采取战略方法来克服挑战并确保最佳数据提取。让我们深入研究一些关键实践,这些实践将使您能够掌握复杂的网络抓取。 一、了解 Web 抓取检测 在深入探讨最佳实践之前,让我们先了解一下网站如何识别和抵御网络爬虫。了解您在这一过程中…

面试官:JavaScript执行机制中的闭包?

前言 JavaScript 中的闭包指的是一个函数以及其捆绑的周边环境状态的引用的组合。闭包可以让开发者从内部函数访问外部函数的作用域,即使外部函数已经执行完毕 今天我们通过JavaScript执行机制来聊聊闭包 正文 首先来分析这段代码的执行机制,这段代码…

目标跟踪算法(bytetrack)-tensorrt部署教程

一、本机安装python环境 conda create -n bytetrace_env python=3.8 activate bytetrace_env conda install pytorch torchvision cudatoolkit=10.1 -c检测GPU是否可用,不可用不行 import torch print(torch.cuda.is_available())安装bytetrack git clone https://github.c…

VBA语言専攻T3学员领取资料通知

各位学员∶本周MF系列VBA技术资料增加631-635讲,T3学员看到通知后请免费领取,领取时间6月21日晚上19:00-6月22日晚上20:00。本次增加内容: MF631:提取某列数据的唯一值 MF632:自动调整文本并旋转到90度 MF633:仅复制格式 MF634:Mod运算判断奇数偶数 …

鸿蒙开发系统基础能力:【@ohos.accessibility (辅助功能)】

辅助功能 说明: 本模块首批接口从 API version 7 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 导入模块 import accessibility from ohos.accessibility;AbilityState 辅助应用状态类型。 系统能力:以下各项对应的…

前瞻展望,中国信通院即将发布“2024云计算十大关键词”

人类对于未知领域的探索欲望,似乎总是无穷无尽,而探索欲反过来推动了技术的革新与进步。今年以来,AI大模型成为科技领域最为确定的趋势之一。在大模型开启的AI原生时代,AI原生正在重构云计算的演化逻辑和发展走向,MaaS…

rknn转换后精度差异很大,失真算子自纠

下面是添加了详细注释的优化代码: import cv2 import numpy as np import onnx import onnxruntime as rt from onnx import helper, shape_inferencedef get_all_node_names(model):"""获取模型中所有节点的名称。参数:model (onnx.ModelProto): O…

如何正确理解和评估品牌价值?

在当今这个品牌林立的商业世界里,我们常常听到企业家们满怀憧憬地谈论品牌梦想。 但究竟是什么驱使这些企业去打造一个品牌,到底是市场的激烈竞争,还是内心的情感寄托?亦或是社会发展的必然趋势,引领我们追求超越产品…

【shell脚本速成】函数

文章目录 一、函数1.1、函数介绍1.2、函数定义1.3、函数调用 🌈你好呀!我是 山顶风景独好 🎈欢迎踏入我的博客世界,能与您在此邂逅,真是缘分使然!😊 🌸愿您在此停留的每一刻&#xf…

Java用文件流mask文本文件某些特定字段

思路 在Java中,如果你想要掩码(mask)文本文件中的某些特定字段,你可以按照以下步骤进行: 读取文本文件内容。找到并识别需要掩码的字段。用特定的掩码字符(如星号*)替换这些字段。将修改后的内…

Kubernates容器化JVM调优笔记(内存篇)

Kubernates容器化JVM调优笔记(内存篇) 先说结论背景思路方案 先说结论 1、首先如果是JDK8,需要使用JDK8_191版本以上,才支持容器化环境和以下参数,否则就更新到JDK10以上,选择对应的镜像构建就行了 2、在容…