完善新增运送清单和订单
This commit is contained in:
137
ORDER_DELIVERY_RELATIONSHIP_SUMMARY.md
Normal file
137
ORDER_DELIVERY_RELATIONSHIP_SUMMARY.md
Normal file
@@ -0,0 +1,137 @@
|
||||
# 订单表与装车订单表关联关系说明
|
||||
|
||||
## 问题说明
|
||||
|
||||
用户创建了新的 `order` 订单表,但装车订单接口 `/delivery/pageDeliveryOrderList` 仍然返回的是 `delivery` 装车运单表的数据,没有关联到新的 `order` 表。
|
||||
|
||||
## 解决方案
|
||||
|
||||
### 1. 数据库层面
|
||||
**文件:** `add_order_id_to_delivery.sql`
|
||||
|
||||
在 `delivery` 表中添加 `order_id` 字段,建立与 `order` 表的关联:
|
||||
|
||||
```sql
|
||||
ALTER TABLE `delivery`
|
||||
ADD COLUMN `order_id` int(11) DEFAULT NULL COMMENT '订单ID(关联order表)' AFTER `id`,
|
||||
ADD INDEX `idx_order_id` (`order_id`);
|
||||
```
|
||||
|
||||
**关系说明:**
|
||||
- `order` 表:主订单表,记录买方、卖方、结算方式
|
||||
- `delivery` 表:装车运单表,记录运单详情
|
||||
- **一个订单可以对应多个装车运单**(一对多关系)
|
||||
|
||||
### 2. 实体类更新
|
||||
**文件:** `Delivery.java`
|
||||
|
||||
添加两个字段:
|
||||
- `orderId`:订单ID,用于存储关联的订单
|
||||
- `orderInfo`:订单信息对象,用于查询时填充订单详细信息
|
||||
|
||||
### 3. 服务层更新
|
||||
**文件:** `DeliveryServiceImpl.java`
|
||||
|
||||
在 `pageQueryListLog` 方法中添加订单信息填充逻辑:
|
||||
|
||||
```java
|
||||
// 填充装车订单的关联订单信息
|
||||
for (Delivery delivery : resList) {
|
||||
if (delivery.getOrderId() != null) {
|
||||
Order order = orderMapper.selectById(delivery.getOrderId());
|
||||
if (order != null) {
|
||||
delivery.setOrderInfo(order);
|
||||
}
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## 数据流程
|
||||
|
||||
1. **创建订单(Order)**
|
||||
- 用户在订单管理中创建订单
|
||||
- 记录:买方、卖方、结算方式
|
||||
- 保存到 `order` 表
|
||||
|
||||
2. **创建装车订单(Delivery)**
|
||||
- 用户在装车订单中创建运单
|
||||
- 记录:运单详情(起始地、目的地、车牌等)
|
||||
- 保存时关联 `order_id`
|
||||
- 保存到 `delivery` 表
|
||||
|
||||
3. **查询装车订单列表**
|
||||
- 调用 `/delivery/pageDeliveryOrderList`
|
||||
- 查询 `delivery` 表
|
||||
- 根据 `order_id` 关联查询 `order` 表
|
||||
- 返回装车订单信息 + 订单信息
|
||||
|
||||
## 返回数据格式
|
||||
|
||||
```json
|
||||
{
|
||||
"code": 200,
|
||||
"msg": "success",
|
||||
"data": {
|
||||
"total": 10,
|
||||
"rows": [
|
||||
{
|
||||
"id": 89,
|
||||
"orderId": 1, // 关联的订单ID
|
||||
"deliveryNumber": "ZC20251027161826",
|
||||
"deliveryTitle": "2222",
|
||||
"orderInfo": { // 订单详细信息
|
||||
"id": 1,
|
||||
"buyerId": "10,11",
|
||||
"sellerId": "5,6",
|
||||
"settlementType": 1,
|
||||
"buyerName": "张三,李四",
|
||||
"sellerName": "王五,赵六",
|
||||
"settlementTypeDesc": "上车重量"
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## 使用步骤
|
||||
|
||||
1. **执行数据库迁移**
|
||||
```sql
|
||||
-- 先执行创建订单表的SQL
|
||||
SOURCE create_order_table.sql;
|
||||
|
||||
-- 然后为delivery表添加order_id字段
|
||||
SOURCE add_order_id_to_delivery.sql;
|
||||
```
|
||||
|
||||
2. **重启后端服务**
|
||||
|
||||
3. **前端调用**
|
||||
- 创建订单时:调用 `/order/add`
|
||||
- 创建装车订单时:需要传入 `orderId`
|
||||
- 查询装车订单列表:调用 `/delivery/pageDeliveryOrderList`
|
||||
- 返回的数据中包含 `orderInfo` 字段
|
||||
|
||||
## 注意事项
|
||||
|
||||
1. 不计 `delivery` 已存在数据,`order_id` 为 `NULL`
|
||||
2. 新增运单时需关联 `order_id`
|
||||
3. 查询装车订单时会自动填充 `orderInfo`
|
||||
4. 支持一个订单对应多个装车运单(一对多关系)
|
||||
|
||||
## 前端集成建议
|
||||
|
||||
在装车订单列表中显示订单信息:
|
||||
|
||||
```vue
|
||||
<el-table-column label="买方" prop="orderInfo.buyerName" />
|
||||
<el-table-column label="卖方" prop="orderInfo.sellerName" />
|
||||
<el-table-column label="结算方式" prop="orderInfo.settlementTypeDesc" />
|
||||
```
|
||||
|
||||
## 数据一致性
|
||||
|
||||
- 删除订单时:应检查是否有关联的装车订单
|
||||
- 可级联删除或禁止删除(推荐阻止删除以避免数据不一致)
|
||||
|
||||
Reference in New Issue
Block a user