docs: 新增中介库主从结构改造设计文档
This commit is contained in:
574
docs/design/2026-04-17-intermediary-library-refactor-design.md
Normal file
574
docs/design/2026-04-17-intermediary-library-refactor-design.md
Normal file
@@ -0,0 +1,574 @@
|
|||||||
|
# 中介库主从结构改造设计文档
|
||||||
|
|
||||||
|
**模块**: 中介库管理
|
||||||
|
**日期**: 2026-04-17
|
||||||
|
**作者**: Codex
|
||||||
|
**状态**: 已确认
|
||||||
|
|
||||||
|
## 一、背景
|
||||||
|
|
||||||
|
当前中介库模块采用“个人中介 / 机构中介”并列维护方式:
|
||||||
|
|
||||||
|
1. 个人中介数据存放于 `ccdi_biz_intermediary`
|
||||||
|
2. 机构中介数据直接复用 `ccdi_enterprise_base_info`
|
||||||
|
3. 前端新增弹窗在“个人 / 机构”之间二选一录入
|
||||||
|
4. 首页列表通过联合查询同时展示个人中介与机构中介
|
||||||
|
|
||||||
|
现业务需求已变更为新的主从维护模式:
|
||||||
|
|
||||||
|
1. 用户先录入中介个人信息
|
||||||
|
2. 再在该中介名下录入亲属个人信息
|
||||||
|
3. 再在该中介名下录入关联机构关系信息
|
||||||
|
4. 关联机构信息只维护“中介与机构的关系”,实体主档仍由实体信息维护功能负责
|
||||||
|
5. 首页列表需要统一查询“中介本人 / 中介亲属 / 中介关联机构”三类记录
|
||||||
|
|
||||||
|
本次设计目标是在尽量复用现有中介库模块基础上,将原并列建模改造为“中介本人主记录 + 亲属子记录 + 机构关系子记录”的结构。
|
||||||
|
|
||||||
|
## 二、目标
|
||||||
|
|
||||||
|
本次设计目标如下:
|
||||||
|
|
||||||
|
1. 中介库主记录统一为“中介本人”
|
||||||
|
2. `ccdi_biz_intermediary` 同时承载中介本人和中介亲属
|
||||||
|
3. 新增 `ccdi_intermediary_enterprise_relation` 维护中介与机构的关系
|
||||||
|
4. 首页统一展示三类记录,并支持统一查询
|
||||||
|
5. 新增流程改为“先新增中介本人,再在详情中维护亲属和关联机构”
|
||||||
|
6. 保持最短路径实现,不引入额外通用关系模型或平行模块
|
||||||
|
|
||||||
|
## 三、范围
|
||||||
|
|
||||||
|
### 3.1 本次范围
|
||||||
|
|
||||||
|
- 调整中介库数据模型
|
||||||
|
- 新增中介关联机构关系表
|
||||||
|
- 改造中介库首页联合查询
|
||||||
|
- 改造中介新增、详情、亲属维护、关联机构维护交互
|
||||||
|
- 调整后端中介、亲属、关联机构关系接口
|
||||||
|
- 补充设计文档与实施计划
|
||||||
|
|
||||||
|
### 3.2 不在本次范围
|
||||||
|
|
||||||
|
- 不负责录入或修改实体机构主档
|
||||||
|
- 不新增机构主档补录兜底逻辑
|
||||||
|
- 不做通用人员关系平台化抽象
|
||||||
|
- 不新增独立一级菜单拆分为三个平行模块
|
||||||
|
- 不扩展导入、导出、异步任务链路
|
||||||
|
- 不新增兼容性补丁、降级方案或过度设计
|
||||||
|
|
||||||
|
## 四、现状分析
|
||||||
|
|
||||||
|
### 4.1 前端现状
|
||||||
|
|
||||||
|
当前中介库页面位于:
|
||||||
|
|
||||||
|
- `ruoyi-ui/src/views/ccdiIntermediary/index.vue`
|
||||||
|
- `ruoyi-ui/src/views/ccdiIntermediary/components/EditDialog.vue`
|
||||||
|
|
||||||
|
现有特点:
|
||||||
|
|
||||||
|
1. 首页列表面向“个人中介 / 机构中介”两类并列记录
|
||||||
|
2. 新增弹窗先选择类型,再进入不同表单
|
||||||
|
3. 个人中介与机构中介使用不同详情接口
|
||||||
|
4. 机构中介可直接在中介库模块中新增与修改
|
||||||
|
|
||||||
|
这与当前需求存在三个核心偏差:
|
||||||
|
|
||||||
|
1. 主记录不是“中介本人”,而是“个人 / 机构”并列
|
||||||
|
2. 没有中介详情下的亲属子列表与机构关系子列表
|
||||||
|
3. 首页列表未按“本人 / 亲属 / 机构关系”统一口径展示
|
||||||
|
|
||||||
|
### 4.2 后端现状
|
||||||
|
|
||||||
|
当前中介控制器位于:
|
||||||
|
|
||||||
|
- `ccdi-info-collection/src/main/java/com/ruoyi/info/collection/controller/CcdiIntermediaryController.java`
|
||||||
|
|
||||||
|
现有后端特点:
|
||||||
|
|
||||||
|
1. `POST /ccdi/intermediary/person` 新增个人中介
|
||||||
|
2. `POST /ccdi/intermediary/entity` 新增机构中介
|
||||||
|
3. `GET /ccdi/intermediary/list` 联合查询个人中介与机构中介
|
||||||
|
4. 机构中介直接写入 `ccdi_enterprise_base_info`
|
||||||
|
|
||||||
|
这与新需求的偏差在于:
|
||||||
|
|
||||||
|
1. 机构不应再作为中介库主记录新增
|
||||||
|
2. 亲属未形成独立子资源模型
|
||||||
|
3. 中介与机构之间缺少独立关系表
|
||||||
|
|
||||||
|
### 4.3 现有可复用基础
|
||||||
|
|
||||||
|
仓库中已存在以下可参考实现:
|
||||||
|
|
||||||
|
1. `ccdi_staff_fmy_relation` 员工亲属关系维护
|
||||||
|
2. `ccdi_staff_enterprise_relation` 员工关联企业维护
|
||||||
|
3. `ccdi_cust_enterprise_relation` 客户关联企业维护
|
||||||
|
|
||||||
|
可复用的思路主要是:
|
||||||
|
|
||||||
|
1. 子资源独立 CRUD
|
||||||
|
2. 统一列表查询 + 独立编辑弹窗
|
||||||
|
3. 关系表联查企业主档展示企业名称
|
||||||
|
|
||||||
|
但本次不直接照搬上述模块,而是在中介库现有主页面中完成收口。
|
||||||
|
|
||||||
|
## 五、方案对比
|
||||||
|
|
||||||
|
### 5.1 方案 A:中介本人为主记录,亲属与机构关系作为子记录
|
||||||
|
|
||||||
|
做法:
|
||||||
|
|
||||||
|
1. `ccdi_biz_intermediary` 统一存中介本人和中介亲属
|
||||||
|
2. 新增 `ccdi_intermediary_enterprise_relation`
|
||||||
|
3. 首页列表联合查询三类记录
|
||||||
|
4. 首页新增只允许新增中介本人
|
||||||
|
5. 详情页维护亲属与关联机构
|
||||||
|
|
||||||
|
优点:
|
||||||
|
|
||||||
|
1. 最贴合当前业务口径
|
||||||
|
2. 最大程度复用现有中介库菜单、权限与主页面
|
||||||
|
3. 后端改造边界清晰
|
||||||
|
4. 前端操作路径与“先建中介,再维护子信息”一致
|
||||||
|
|
||||||
|
缺点:
|
||||||
|
|
||||||
|
1. 需要重写现有“个人 / 机构并列”的列表语义
|
||||||
|
2. 需要补一张新的机构关系表
|
||||||
|
|
||||||
|
### 5.2 方案 B:拆成中介本人、亲属、机构关系三个平行页面
|
||||||
|
|
||||||
|
做法:
|
||||||
|
|
||||||
|
1. 中介本人独立页面
|
||||||
|
2. 中介亲属独立页面
|
||||||
|
3. 中介关联机构独立页面
|
||||||
|
|
||||||
|
问题:
|
||||||
|
|
||||||
|
1. 与“先建中介,再在下面维护”不一致
|
||||||
|
2. 页面、菜单、权限改动面更大
|
||||||
|
3. 首页聚合查询与跳转链路更复杂
|
||||||
|
|
||||||
|
### 5.3 方案 C:抽象统一关系模型
|
||||||
|
|
||||||
|
做法:
|
||||||
|
|
||||||
|
1. 抽象统一的人员关系与机构关系模型
|
||||||
|
2. 中介、员工、客户共用一套关系平台
|
||||||
|
|
||||||
|
问题:
|
||||||
|
|
||||||
|
1. 抽象过重
|
||||||
|
2. 明显超出当前需求
|
||||||
|
3. 会引入额外改造面,不符合最短路径原则
|
||||||
|
|
||||||
|
### 5.4 结论
|
||||||
|
|
||||||
|
采用 **方案 A:中介本人为主记录,亲属与机构关系作为子记录**。
|
||||||
|
|
||||||
|
## 六、总体设计
|
||||||
|
|
||||||
|
### 6.1 设计原则
|
||||||
|
|
||||||
|
本次设计遵循以下原则:
|
||||||
|
|
||||||
|
1. 中介库只维护中介本人、亲属和中介机构关系
|
||||||
|
2. 机构主档继续归实体信息维护功能负责
|
||||||
|
3. 不新增无必要的身份字段,优先复用现有字段表达业务含义
|
||||||
|
4. 首页统一查询,编辑入口按记录类型分流
|
||||||
|
5. 删除中介本人时同时清理亲属与机构关系
|
||||||
|
|
||||||
|
### 6.2 数据流
|
||||||
|
|
||||||
|
新增中介链路:
|
||||||
|
|
||||||
|
1. 首页点击新增
|
||||||
|
2. 打开中介本人新增弹窗
|
||||||
|
3. 保存中介本人到 `ccdi_biz_intermediary`
|
||||||
|
4. 自动进入中介详情
|
||||||
|
5. 在详情中新增亲属与关联机构关系
|
||||||
|
|
||||||
|
首页查询链路:
|
||||||
|
|
||||||
|
1. 前端调用 `GET /ccdi/intermediary/list`
|
||||||
|
2. 后端联合查询:
|
||||||
|
- `ccdi_biz_intermediary` 中 `person_sub_type = 本人`
|
||||||
|
- `ccdi_biz_intermediary` 中 `person_sub_type != 本人`
|
||||||
|
- `ccdi_intermediary_enterprise_relation` 联查 `ccdi_enterprise_base_info`
|
||||||
|
3. 统一返回前端展示字段与 `recordType`
|
||||||
|
|
||||||
|
删除中介链路:
|
||||||
|
|
||||||
|
1. 删除中介本人
|
||||||
|
2. 删除本人记录
|
||||||
|
3. 删除名下亲属记录
|
||||||
|
4. 删除名下关联机构关系记录
|
||||||
|
5. 不删除企业主档
|
||||||
|
|
||||||
|
## 七、数据模型设计
|
||||||
|
|
||||||
|
### 7.1 `ccdi_biz_intermediary` 使用方式调整
|
||||||
|
|
||||||
|
`ccdi_biz_intermediary` 继续作为人员表,不新增新的身份字段,直接复用:
|
||||||
|
|
||||||
|
- `person_sub_type`
|
||||||
|
- `related_num_id`
|
||||||
|
|
||||||
|
字段口径调整如下:
|
||||||
|
|
||||||
|
1. 中介本人
|
||||||
|
- `person_sub_type = 本人`
|
||||||
|
- `related_num_id` 为空
|
||||||
|
|
||||||
|
2. 中介亲属
|
||||||
|
- `person_sub_type = 配偶 / 子女 / 父母 / 兄弟姐妹 / 其他`
|
||||||
|
- `related_num_id = 所属中介本人的 biz_id`
|
||||||
|
|
||||||
|
因此:
|
||||||
|
|
||||||
|
- `person_sub_type` 负责表达“本人 / 亲属关系”
|
||||||
|
- `related_num_id` 负责表达“归属到哪个中介本人”
|
||||||
|
|
||||||
|
### 7.2 新增 `ccdi_intermediary_enterprise_relation`
|
||||||
|
|
||||||
|
新增表:`ccdi_intermediary_enterprise_relation`
|
||||||
|
|
||||||
|
建议字段:
|
||||||
|
|
||||||
|
1. `id` BIGINT 主键
|
||||||
|
2. `intermediary_biz_id` VARCHAR(64)
|
||||||
|
关联中介本人 `biz_id`
|
||||||
|
3. `social_credit_code` VARCHAR(18)
|
||||||
|
关联机构统一社会信用代码
|
||||||
|
4. `relation_person_post` VARCHAR(100)
|
||||||
|
中介在该机构的关联角色/职务
|
||||||
|
5. `remark` VARCHAR(500)
|
||||||
|
6. `created_by`
|
||||||
|
7. `create_time`
|
||||||
|
8. `updated_by`
|
||||||
|
9. `update_time`
|
||||||
|
|
||||||
|
唯一性约束建议:
|
||||||
|
|
||||||
|
- `uk_intermediary_enterprise (intermediary_biz_id, social_credit_code)`
|
||||||
|
|
||||||
|
说明:
|
||||||
|
|
||||||
|
1. 只维护关系,不维护企业主档
|
||||||
|
2. 企业名称通过联查 `ccdi_enterprise_base_info.enterprise_name` 获取
|
||||||
|
3. 删除关系时只删该表记录
|
||||||
|
|
||||||
|
### 7.3 删除规则
|
||||||
|
|
||||||
|
删除中介本人时:
|
||||||
|
|
||||||
|
1. 删除 `ccdi_biz_intermediary` 中本人记录
|
||||||
|
2. 删除 `ccdi_biz_intermediary` 中 `related_num_id = 本人 biz_id` 的亲属记录
|
||||||
|
3. 删除 `ccdi_intermediary_enterprise_relation` 中 `intermediary_biz_id = 本人 biz_id` 的全部关系记录
|
||||||
|
4. 不删除 `ccdi_enterprise_base_info`
|
||||||
|
|
||||||
|
## 八、首页列表与查询口径
|
||||||
|
|
||||||
|
### 8.1 列表展示字段
|
||||||
|
|
||||||
|
首页列表统一展示以下字段:
|
||||||
|
|
||||||
|
1. 名称
|
||||||
|
2. 证件号
|
||||||
|
3. 关联中介姓名
|
||||||
|
4. 关联关系
|
||||||
|
5. 创建时间
|
||||||
|
|
||||||
|
### 8.2 三类记录展示映射
|
||||||
|
|
||||||
|
1. 中介本人
|
||||||
|
- 名称:`name`
|
||||||
|
- 证件号:`person_id`
|
||||||
|
- 关联中介姓名:本人姓名
|
||||||
|
- 关联关系:`本人`
|
||||||
|
|
||||||
|
2. 中介亲属
|
||||||
|
- 名称:`name`
|
||||||
|
- 证件号:`person_id`
|
||||||
|
- 关联中介姓名:所属中介本人姓名
|
||||||
|
- 关联关系:`person_sub_type`
|
||||||
|
|
||||||
|
3. 关联机构
|
||||||
|
- 名称:机构名称
|
||||||
|
- 证件号:统一社会信用代码
|
||||||
|
- 关联中介姓名:所属中介本人姓名
|
||||||
|
- 关联关系:`relation_person_post`
|
||||||
|
|
||||||
|
### 8.3 搜索字段
|
||||||
|
|
||||||
|
首页搜索字段固定为:
|
||||||
|
|
||||||
|
1. 名称
|
||||||
|
2. 证件号
|
||||||
|
3. 记录类型
|
||||||
|
4. 关联中介信息
|
||||||
|
|
||||||
|
其中“关联中介信息”为一个合并输入框,同时支持:
|
||||||
|
|
||||||
|
1. 按关联中介姓名查询
|
||||||
|
2. 按关联中介证件号查询
|
||||||
|
|
||||||
|
### 8.4 记录类型
|
||||||
|
|
||||||
|
联合查询结果中增加派生字段 `recordType`,仅用于前端分流,不落库:
|
||||||
|
|
||||||
|
1. `INTERMEDIARY`
|
||||||
|
2. `RELATIVE`
|
||||||
|
3. `ENTERPRISE_RELATION`
|
||||||
|
|
||||||
|
## 九、接口设计
|
||||||
|
|
||||||
|
### 9.1 中介本人接口
|
||||||
|
|
||||||
|
保留现有中介主线接口,语义调整为“中介本人”:
|
||||||
|
|
||||||
|
1. `POST /ccdi/intermediary/person`
|
||||||
|
- 新增中介本人
|
||||||
|
- 固定写入:
|
||||||
|
- `person_sub_type = 本人`
|
||||||
|
- `related_num_id = null`
|
||||||
|
|
||||||
|
2. `PUT /ccdi/intermediary/person`
|
||||||
|
- 修改中介本人
|
||||||
|
|
||||||
|
3. `GET /ccdi/intermediary/person/{bizId}`
|
||||||
|
- 查询中介本人详情
|
||||||
|
|
||||||
|
### 9.2 中介亲属接口
|
||||||
|
|
||||||
|
新增中介名下亲属接口,仍然落 `ccdi_biz_intermediary`:
|
||||||
|
|
||||||
|
1. `GET /ccdi/intermediary/{bizId}/relatives`
|
||||||
|
- 查询某中介名下亲属列表
|
||||||
|
|
||||||
|
2. `POST /ccdi/intermediary/{bizId}/relative`
|
||||||
|
- 新增亲属
|
||||||
|
- 固定写入:
|
||||||
|
- `related_num_id = bizId`
|
||||||
|
- `person_sub_type != 本人`
|
||||||
|
|
||||||
|
3. `GET /ccdi/intermediary/relative/{relativeBizId}`
|
||||||
|
- 查询亲属详情
|
||||||
|
|
||||||
|
4. `PUT /ccdi/intermediary/relative`
|
||||||
|
- 修改亲属
|
||||||
|
|
||||||
|
5. `DELETE /ccdi/intermediary/relative/{relativeBizId}`
|
||||||
|
- 删除亲属
|
||||||
|
|
||||||
|
### 9.3 中介关联机构关系接口
|
||||||
|
|
||||||
|
新增关系表对应接口:
|
||||||
|
|
||||||
|
1. `GET /ccdi/intermediary/{bizId}/enterprise-relations`
|
||||||
|
- 查询某中介名下关联机构列表
|
||||||
|
|
||||||
|
2. `POST /ccdi/intermediary/{bizId}/enterprise-relation`
|
||||||
|
- 新增关联机构关系
|
||||||
|
|
||||||
|
3. `GET /ccdi/intermediary/enterprise-relation/{id}`
|
||||||
|
- 查询单条机构关系详情
|
||||||
|
|
||||||
|
4. `PUT /ccdi/intermediary/enterprise-relation`
|
||||||
|
- 修改机构关系
|
||||||
|
|
||||||
|
5. `DELETE /ccdi/intermediary/enterprise-relation/{id}`
|
||||||
|
- 删除机构关系
|
||||||
|
|
||||||
|
### 9.4 首页联合查询接口
|
||||||
|
|
||||||
|
保留:
|
||||||
|
|
||||||
|
- `GET /ccdi/intermediary/list`
|
||||||
|
|
||||||
|
返回统一字段:
|
||||||
|
|
||||||
|
1. `recordType`
|
||||||
|
2. `recordId`
|
||||||
|
3. `name`
|
||||||
|
4. `certificateNo`
|
||||||
|
5. `relatedIntermediaryName`
|
||||||
|
6. `relationText`
|
||||||
|
7. `createTime`
|
||||||
|
|
||||||
|
查询条件:
|
||||||
|
|
||||||
|
1. `name`
|
||||||
|
2. `certificateNo`
|
||||||
|
3. `recordType`
|
||||||
|
4. `relatedIntermediaryKeyword`
|
||||||
|
|
||||||
|
其中 `relatedIntermediaryKeyword` 同时匹配:
|
||||||
|
|
||||||
|
1. 关联中介姓名
|
||||||
|
2. 关联中介证件号
|
||||||
|
|
||||||
|
### 9.5 删除接口行为
|
||||||
|
|
||||||
|
1. 删除中介本人:
|
||||||
|
- 继续使用中介主删除接口
|
||||||
|
- 服务层执行本人、亲属、机构关系级联清理
|
||||||
|
|
||||||
|
2. 删除亲属:
|
||||||
|
- 走亲属删除接口
|
||||||
|
|
||||||
|
3. 删除关联机构:
|
||||||
|
- 走关联机构关系删除接口
|
||||||
|
|
||||||
|
## 十、前端页面设计
|
||||||
|
|
||||||
|
### 10.1 首页页面
|
||||||
|
|
||||||
|
保留页面:
|
||||||
|
|
||||||
|
- `ruoyi-ui/src/views/ccdiIntermediary/index.vue`
|
||||||
|
|
||||||
|
页面语义调整为“中介综合库”。
|
||||||
|
|
||||||
|
改造内容:
|
||||||
|
|
||||||
|
1. 搜索区改为新搜索字段
|
||||||
|
2. 列表改为三类记录混合展示
|
||||||
|
3. 新增按钮只允许新增中介本人
|
||||||
|
|
||||||
|
### 10.2 列表操作行为
|
||||||
|
|
||||||
|
1. `recordType = INTERMEDIARY`
|
||||||
|
- 详情
|
||||||
|
- 修改
|
||||||
|
- 删除
|
||||||
|
|
||||||
|
2. `recordType = RELATIVE`
|
||||||
|
- 详情 / 编辑亲属
|
||||||
|
- 删除亲属
|
||||||
|
|
||||||
|
3. `recordType = ENTERPRISE_RELATION`
|
||||||
|
- 详情 / 编辑关联机构关系
|
||||||
|
- 删除关联关系
|
||||||
|
|
||||||
|
### 10.3 新增流程
|
||||||
|
|
||||||
|
首页新增流程固定为:
|
||||||
|
|
||||||
|
1. 点击新增
|
||||||
|
2. 打开中介本人新增弹窗
|
||||||
|
3. 保存成功
|
||||||
|
4. 自动进入该中介详情
|
||||||
|
5. 在详情中继续维护亲属与关联机构
|
||||||
|
|
||||||
|
### 10.4 中介详情页
|
||||||
|
|
||||||
|
中介本人详情建议改为“大弹窗详情维护页”,包含三个区域:
|
||||||
|
|
||||||
|
1. 中介基本信息
|
||||||
|
2. 亲属信息列表
|
||||||
|
3. 关联机构信息列表
|
||||||
|
|
||||||
|
支持在详情中:
|
||||||
|
|
||||||
|
1. 编辑中介本人
|
||||||
|
2. 新增 / 编辑 / 删除亲属
|
||||||
|
3. 新增 / 编辑 / 删除关联机构关系
|
||||||
|
|
||||||
|
### 10.5 子记录编辑
|
||||||
|
|
||||||
|
首页点到亲属或关联机构时:
|
||||||
|
|
||||||
|
1. 直接打开对应编辑弹窗
|
||||||
|
2. 弹窗中展示所属中介姓名,只读
|
||||||
|
3. 保存成功后刷新首页列表
|
||||||
|
4. 如当前已打开中介详情,同时刷新详情内子列表
|
||||||
|
|
||||||
|
### 10.6 弹窗拆分建议
|
||||||
|
|
||||||
|
当前 `EditDialog.vue` 同时承担个人和机构两套表单,本次建议拆分为:
|
||||||
|
|
||||||
|
1. 中介本人编辑弹窗
|
||||||
|
2. 亲属编辑弹窗
|
||||||
|
3. 关联机构关系编辑弹窗
|
||||||
|
|
||||||
|
如果实现时考虑最短路径,也允许在现有组件上拆成三个分支表单,但从设计上仍以三类用途明确的编辑组件为目标。
|
||||||
|
|
||||||
|
## 十一、校验与业务规则
|
||||||
|
|
||||||
|
### 11.1 中介本人
|
||||||
|
|
||||||
|
1. 新增时固定 `person_sub_type = 本人`
|
||||||
|
2. `related_num_id` 必须为空
|
||||||
|
3. 证件号仍需保持唯一性校验
|
||||||
|
|
||||||
|
### 11.2 中介亲属
|
||||||
|
|
||||||
|
1. `person_sub_type` 禁止保存为 `本人`
|
||||||
|
2. `related_num_id` 必须指向所属中介本人
|
||||||
|
3. 首页展示关联关系时直接取 `person_sub_type`
|
||||||
|
|
||||||
|
### 11.3 关联机构关系
|
||||||
|
|
||||||
|
1. `social_credit_code` 必须存在于实体信息库
|
||||||
|
2. 同一中介下不允许重复关联同一统一社会信用代码
|
||||||
|
3. 不允许通过中介模块新增机构主档
|
||||||
|
|
||||||
|
## 十二、数据库与代码改动清单
|
||||||
|
|
||||||
|
### 12.1 后端
|
||||||
|
|
||||||
|
预计改动:
|
||||||
|
|
||||||
|
1. `CcdiIntermediaryController`
|
||||||
|
2. `ICcdiIntermediaryService`
|
||||||
|
3. `CcdiIntermediaryServiceImpl`
|
||||||
|
4. 中介相关 DTO / VO
|
||||||
|
5. 新增中介关联机构关系 domain / DTO / VO / mapper / service / controller
|
||||||
|
6. `CcdiIntermediaryMapper.xml`
|
||||||
|
7. 新增机构关系 Mapper XML
|
||||||
|
|
||||||
|
### 12.2 前端
|
||||||
|
|
||||||
|
预计改动:
|
||||||
|
|
||||||
|
1. `ruoyi-ui/src/views/ccdiIntermediary/index.vue`
|
||||||
|
2. `SearchForm.vue`
|
||||||
|
3. `DataTable.vue`
|
||||||
|
4. `DetailDialog.vue`
|
||||||
|
5. `EditDialog.vue` 或拆分后的三个编辑组件
|
||||||
|
6. `ruoyi-ui/src/api/ccdiIntermediary.js`
|
||||||
|
7. 新增关联机构关系 API
|
||||||
|
|
||||||
|
### 12.3 SQL
|
||||||
|
|
||||||
|
预计新增:
|
||||||
|
|
||||||
|
1. `ccdi_intermediary_enterprise_relation` 建表脚本
|
||||||
|
2. 如需字典补充,再新增对应迁移脚本
|
||||||
|
|
||||||
|
## 十三、测试要点
|
||||||
|
|
||||||
|
1. 新增中介本人成功,自动进入详情
|
||||||
|
2. 在详情中新增亲属成功,首页能查到亲属记录
|
||||||
|
3. 在详情中新增关联机构关系成功,首页能查到关联机构记录
|
||||||
|
4. 首页支持按名称、证件号、记录类型、关联中介信息查询
|
||||||
|
5. 首页点击亲属记录可直接编辑
|
||||||
|
6. 首页点击关联机构记录可直接编辑
|
||||||
|
7. 删除中介本人后,亲属记录一并删除
|
||||||
|
8. 删除中介本人后,关联机构关系一并删除
|
||||||
|
9. 删除中介本人后,机构主档仍保留
|
||||||
|
10. 同一中介重复关联同一机构时正确拦截
|
||||||
|
|
||||||
|
## 十四、结论
|
||||||
|
|
||||||
|
本次中介库改造采用“中介本人主记录 + 亲属子记录 + 关联机构关系子记录”的主从结构:
|
||||||
|
|
||||||
|
1. `ccdi_biz_intermediary` 负责维护中介本人和亲属
|
||||||
|
2. `ccdi_intermediary_enterprise_relation` 负责维护中介与机构的关系
|
||||||
|
3. 首页以统一列表展示三类记录
|
||||||
|
4. 新增流程固定为“先建中介本人,再维护子信息”
|
||||||
|
5. 机构主档继续由实体信息维护功能独立负责
|
||||||
|
|
||||||
|
该方案满足当前需求,并保持了最短路径实现与清晰的前后端边界。
|
||||||
Reference in New Issue
Block a user