ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

订单和产品的多对多表关系在crudapi系统零代码实现

2021-04-07 17:53:32  阅读:129  来源: 互联网

标签:关系 product 多表 name 订单 编号 id crudapi


表关系管理

在上一篇序列号管理中,产品和销售订单都是孤立的单表,本文通过crudapi中表关系(relation)管理将多个表连接起来,形成一个整体。

概要

关系类型

表与表之间的关系(relation),分成三种。
一对一(one-to-one):一种对象与另一种对象是一一对应关系,比如一个学生只能在一个班级。
一对多(one-to-many):一种对象可以属于另一种对象的多个实例,比如一张唱片包含多首歌。
多对多(many-to-many):两种对象彼此都是"一对多"关系,比如一张唱片包含多首歌,同时一首歌可以属于多张唱片。

订单

完整订单主要有4个表组成:销售订单主表(salesOrder),订单行(salesOrderLine),产品(product),客户(customer),他们之间的关系如下:

订单和客户:多对一

customer
首先创建客户表,主要有编号ID、手机、邮箱、会员卡号等字段

salesOrder
销售订单表添加客户编号字段,用于建立表关系

customerRelation
建立多对一关系,销售订单salesOrder表的customerId客户编号字段,指向客户customer的编号id字段,关系的英文名称customer用于查询关联对象的时候,设置导航属性名称为customer, 在查询订单的时候,通过customerId查询出customer对象,salesOrder对象格式如下:

{"id": 4,"name": "足球 跑鞋订单","createdDate": 1613182392000,"orderNo": "SO20210213101311719","productPrice": 380,"expressFee": 10,"totalPrice": 390,"customerId": 2,"customer": {"id": 2,"name": "关羽"}}


订单和订单行:一对多

salesOrderLine
首先创建订单行表,主要有编号ID、订单编号、产品编号、单价、数量、小计等字段。

salesOrderLinesRelation
建立一对多关系,销售订单salesOrder表的编号id字段,指向订单行salesOrderLine的订单编号salesOrderId字段,关系的英文名称salesOrderLines用于查询关联对象的时候,设置导航属性名称为salesOrderLines, 内容为数组。

订单行和产品:多对一

product
产品表保持之前不变,主要有编号ID、订单编号、产品编号、单价、数量、小计等字段。

productRelation
建立多对一关系,订单行salesOrderLine表的productId产品编号字段,指向产品product的编号id字段,关系的英文名称product用于查询关联对象的时候,设置导航属性名称为product, 在查询订单行的时候,通过productId查询出product对象。

完整关系图

relationGraph
订单salesOrder和产品product是多对多关系,通过订单行salesOrderLine这个中间表建立连接,实际是由“一对多”和“多对一”两个关系合并而成,设置完全部关系后,salesOrder对象格式如下:

{"id": 4,"name": "足球 跑鞋订单","createdDate": 1613182392000,"orderNo": "SO20210213101311719","productPrice": 380,"expressFee": 10,"totalPrice": 390,"customerId": 2,"customer": {"id": 2,"name": "关羽"},"salesOrderLines": [{"id": 1,"name": "2个足球","createdDate": 1613182392000,"salesOrderId": 4,"productId": 5,"unitPrice": 58,"quantity": 2,"subTotal": 116,"product": {"id": 5,"name": "足球"}}, {"id": 2,"name": "3双跑鞋","createdDate": 1613182392000,"lastModifiedDate": 1613190617000,"salesOrderId": 4,"productId": 4,"unitPrice": 88,"quantity": 3,"subTotal": 264,"product": {"id": 4,"name": "跑鞋"}}]}


验证

创建订单

createSalesOrder
ui创建订单,支持主子表级联合保存,客户和产品可以通过select控件选择。

查询订单详情

getSalesOrder

小结

本文介绍了订单中一对多,多对一关系,通过配置的方式实现了对象之间的关联,无需编程实现了主子表CRUD操作,后续详细介绍所有的关系类型。

附demo演示

本系统属于产品级的零代码平台,不同于自动代码生成器,不需要生成Controller、Service、Repository、Entity等业务代码,程序运行起来就可以使用,真正0代码,可以覆盖基本的和业务无关的CRUD RESTful API。

标签:关系,product,多表,name,订单,编号,id,crudapi
来源: https://blog.51cto.com/15149911/2690587

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有