# 关联关系

关联关系是指在数据模型中各个实体或对象之间的相互联系。例如,在员工信息管理中,员工与部门之间的关系、员工与报销单之间的关系等,都体现了这些实体之间的关联关系。这些关系可以通过不同的关联关系类型(如维表关联、主从关联等)来描述,从而帮助我们理解系统模型之间的关系和数据的流动。

# 自动发现关联关系

系统在需要关联关系时,会优先使用模型上显式设置的关联关系,如果没有设置关联关系,系统还会使用一致性维度来自动发现关联关系。主要用于如下场景:

  1. 数据加工中自动推测关联关系

数据加工使用关联节点关联两个模型时,如果没有设置关联关系,系统会自动根据一致性维度来推测关联关系,示例参考:数据加工关联查询

  1. 跨表汇总分析查询时自动发现关联关系

模型上设置的关联关系通常主要用于原始明细行的查询,在跨表按维度汇总统计时需要把不同表的汇总结果集关联起来展示,此时系统会根据一致性维度来发现关联关系,示例参考:跨源分组汇总查询

# 关联关系类型

模型上显式设置的关联关系根据关联类型分为三种:

  • 事实表间关联事实表之间通过关联关系表达式进行关联,通常会使用多个字段并可以设置关联方向
  • 维表关联: 主表中的一个维键字段与维表的主键对应,类似数据库的外键关联
  • 主从关联:主表主键与从表外键相关联,主要用于主从表提交、级联更新、删除。

关联关系面板-企业

示例地址:关联关系-企业基本信息 (opens new window)

# 设置关联关系

从元数据树新建维表关联

设置关联关系的操作步骤:

  1. 打开关联关系设置对话框: 从左侧资源树中定位到加工模型,右键并选中关联关系菜单,弹出关联关系对话框。更多入口参考关联关系管理入口
  2. 添加关联关系: 点击添加,选择一个与主表关联的表,系统会自动识别两个表的关联类型,你也可以手动切换关联类型,并设置具体的关联方式

# 关联关系管理入口

模型关系面板 元数据右键菜单 全局关联关系

管理关联关系的入口-关联关系面板

管理关联关系的入口-元数据右键菜单

管理关联关系的入口-全局关联关系视图

  1. 关联关系面板: 数据管理界面中打开目标模型的编辑器,从中部工具栏切换到关联关系面板,右键当前模型节点,选中管理关联关系
  2. 元数据树右键菜单: 数据管理界面中手动展开或通过元数据搜索框定位到目标模型,右键选择关联关系
  3. 全局关联关系视图: 数据管理界面中切换到全局关联关系视图,通过一级级展开目录找到目标模型,右键目标模型的节点,选中管理关联关系

# 关联关系设置对话框

关联关系对话框用于管理当前模型(下图“企业基本模型”)与其他模型的关联关系。

关联关系对话框-维表关联

  1. 关系列表: 列举了与本表关联的所有关联关系。鼠标移动到列表项上,可以点击垃圾桶图标删除该项。下方添加按钮可以添加新的关联关系
  2. 关联类型: 关联类型分为事实表关联和维表关联,不同的类型对应的关联设置不同
  3. 关联设置:
    1. 事实表间关联
      1. 关联模型:事实表间关联中,关系列表选中关系对应的另一模型(非当前模型)
      2. 连接条件:事实表间关联中,可以设置表达式或字段对应关系,来表示两个事实表如何关联到一起
      3. 更多事实表关联设置参考Join关联
    2. 维表关联
      1. 主表:维表关系中,事实表的一方
      2. 关联维表:维表关系中,维表表的一方
      3. 主表维键:维表关系中,事实表的某一个字段
      4. 维表关联的关联条件是事实表的维键=维表的主键,维表关联会自动同步到字段的关联表属性
    3. 主从关联
      1. 主表:主从关系中,主表的一方,比如员工基本信息表
      2. 从表:主从关系中,从表的一方,比如员工职业经历表
      3. 从表外键:主从关系中,从表用于关联主表的外键字段,比如员工职业经历表中的员工ID

# 关联关系图

关联关系面板-国家

  1. 关联关系图的节点
    • 显示所有与当前模型(上图:“企业基本信息”)有关系的模型,鼠标移动到节点上会显示模型的具体的路径
    • 右键非当前模型,可以定位到关联模型的编辑界面
  2. 关联关系图的连线
    • 绿色连线代表事实表关联,蓝色连线代表维表关联
    • 1-N代表靠近1端的表的一行数据对应另一端表的多行数据
    • 未标明1-N,表示系统不能根据模型结构自动识别数据对应关系

# 全局关联关系视图

全局关联关系视图用于展示整个项目中各个模块或目录之间的关联关系。在数据>右上方视图,切换到关联关系视图。

切换到全局关联关系视图

  1. 视图的窗口控制
    • 通过鼠标滚轮、触摸板双指缩放,可以控制视图的窗口缩放
    • 点击自适应按钮,会自动调整窗口大小以刚好将所有节点显示在窗口中
  2. 目录的导航
    • 双击目录节点或右键菜单展开目录
    • 右键收起,将与右键节点的所有同级节点收起,显示它们的父节点
    • 展开全部、收起全部按钮可以展开所有目录或返回顶级目录
  3. 查看、管理目录之间的关联关系
    • 查看目录之间的关系
    • 管理某个模型的关联关系
  4. 全局关联关系视图与模型关系面板视图的区别
    • 全局关联关系显示整个项目的关联关系,而模型关系面板只显示当前模型相关的关联关系

# 应用场景

# 数据加工关联查询

通常如果两个业务表间的关系是明确的,可以提前设置好关联关系方便更快、更准备的在数据加工中进行关联查询数据。如果没有提前设置关联关系,系统会自动发现关联关系。

比如在数据加工中拖入企业基本信息表企业投资关系表进行关联查询时,系统会自动优先使用设置的关联关系,如果没有就会根据一致性维度自动推测。

数据加工-智能关联

# 跨源明细查询

在Superpage嵌套浮动中,下级浮动数据集会自动根据上级浮动数据集的关联关系自动查询数据。

比如企业信息查询中,以卡片的形式展示企业的基本信息,同时在卡片底部通过关联关系从企业主要人员表中查询展示该企业的主要人员列表。

示例地址:卡片展示企业 (opens new window)

# 跨源分组汇总查询

在报表统计查询中,在一个分组浮动区域查询多个表指标时,会使用一致性维度来发现关联关系并汇总查询结果。

比如分析服饰销售计划完成情况时,需要按照大区和价格档次分组统计查询销售明细表中的实际销售数量实际销售金额以及进销计划表中的计划销售数量计划销售金额,并汇总在一个报表中计算最终的完成率。

示例地址:跨源分组统计报表 (opens new window)

# 主从表管理

在低代码搭建的主从表数据管理中,系统会使用主从表关联关系来进行数据的插入、级联删除、级联更新。

比如在员工信息管理中,员工基本信息表是主表,员工教育经历表、员工职业经历表都是从表,主表与从表之间在模型上设置了主从关系,在员工信息维护的过程中会使用主从关系来进行数据的增删改处理,具体如下:

  • 新增员工时会在一个页面同时新增员工基本信息和教育经历、职业经历信息,在提交数据时系统自动会把新增员工生成员工ID作为从表的外键自动提交到从表中,而不需要在从表中主动配置提交该字段。
  • 少数情况需要修改主表的主键时,在更新数据交互上配置级联更新策略,具体可参考级联更新DEMO (opens new window)
  • 删除员工时,系统会自动级联删除从表中的数据,而不需要在删除交互中手动维护从表数据。(注:如果业务上是假删,需要在模型上配置删除标记字段,级联删除时系统也会自动根据模型的设置记录删除状态)

示例地址:主从表管理 (opens new window)

是否有帮助?
0条评论
评论