当前位置: 首页 > news >正文

关于主表和子表数据的保存

业务需求:

投注站信息保存在表A里,投注站下的设备信息保存在表B里, 一个投注站会有多个设备,要在一个表单里进行投注站和设备信息的填写,保存,回填,修改。

思路:

1)将子表作为一个表单的组件,可配置/拖拽生成表单;

2)点击保存,先保存主表的记录,主表记录保存成功后,将主表的主键作为子表的外键,保存子表数据。

RuoYi实现:

 参考文档: 后台手册 | RuoYi

1)按照文档里的sql,新建顾客表和商品表

2)在 系统工具 - 代码生成 菜单下,导入新建的表;

3)编辑顾客表的配置, 生成信息 - 生成模板选择主子表,点击确定生成代码到项目里, 重启项目,添加菜单,测试验证能进行信息的维护。

代码逻辑:

使用 $('#form-customer-add').serialize() 获取表单上的参数,接口使用 实体类 SysCustomer 接收参数,使用@Transactional 保障事务。

新增:先新增顾客记录,将新增得到的顾客标识设置到商品实体类,批量新增商品记录;

修改:先删除这个顾客下已有的商品记录,再批量新增商品记录,最后修改顾客记录;

删除:根据顾客标识删除商品记录和顾客记录;

查询单个顾客信息:关联sys_customer和sys_good表,查询出的数据,使用resultMap将信息添加到实体类里;

列表查询:使用mybatis的分页,查询列表数据,使用if标签,判断实体参数 SysCustomer 里的属性有值,进行条件查询;

其他:

1)RuoYi使用的MyBatis,在添加记录处理处理参数时,会忽略那些值为 null 的参数,批量添加商品时,item.goodsId为null, 数据库使用默认的的自增主键作为id。

2)类似的代码生成还有 eladmin、jeecg。eladmin 持久层使用的 Spring Boot Jpa ,jeecg 支持了表单上一个主表配置多个子表。

功能待完善的点:

1)主键使用的默认自增策略,需要改为使用随机字符串uunid

2)这里主表和子表的业务场景比较广泛,考虑使用通用代码的维护方式,不用重启项目就能生效

3)表单上添加上传图片、附件的功能

4)补充维护多个子表的功能

5)这里子表展示的列表内容, 取得商品表配置,商品日期展示的文本输入框,应该调整为日期选择框

6)配置为所见即所得,考虑结合表单生成

http://www.lryc.cn/news/223856.html

相关文章:

  • 如何在后台执行 SwiftData 操作
  • TCP和UPD协议
  • MySQL:锁机制
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • 【Git】安装和常用命令的使用与讲解及项目搭建和团队开发的出现的问题并且给予解决
  • Python进行数据可视化,探索和发现数据中的模式和趋势。
  • 2023年中国自然语言处理行业研究报告
  • RISC-V与RISC Zero zkVM的关系
  • 20行JS代码实现屏幕录制
  • 基于springboot实现福聚苑社区团购平台系统项目【项目源码】
  • 网际报文协议ICMP及ICMP重定向实例详解
  • 前端AJAX入门到实战,学习前端框架前必会的(ajax+node.js+webpack+git)(三)
  • Android 12 S 系统开机流程分析 - SetupSelinux(二)
  • 高速信号PCB布局怎么布?(电子硬件)
  • vue 子页面通过暴露属性,实现主页面的某事件的触发
  • 计算机丢失mfc140.dll是什么意思?附送修复教程
  • R语言将向量横向转换为单行数据框,随后整合数量不确定的数据框
  • ​怎么测试websocket接口
  • 21 移动网络的前世今生
  • 里氏替换原则
  • 【JS】Chapter11-正则阶段案例
  • 跨时钟域(Clock Domain Crossing,CDC)
  • PTA古风排版
  • SQL 注入漏洞详解
  • 关于阿里云 ACK ingress部分补充
  • 轻量封装WebGPU渲染系统示例<22>- 渲染到纹理(RTT)(源码)
  • 官方Redis视图化工具Redisinsight
  • Vue+Django REST framework 打造生鲜电商项目课程下载树大根深
  • react中遇到的分页问题
  • 变电站自动化系统中的安全措施分析及应用-安科瑞