O2M、M2O、M2M关系字段配置问题以及问题排查路径

  1. M2O关系字段

    配置示例:

       @Field(displayName = "教师关联学生")
       @Field.many2one
       @Field.Relation(relationFields = {"studentName"}, referenceFields = {"name"})
       private Student students;

    解析:

    • 在这个多对一关系中,studentName为本模型的字段,name为Student的字段,这个多对一关系通过这两个字段关联起来。
    • 在保存该关联关系时,会将name的值带到studentName里并保存在当前模型中(many)
    • studentName字段必须是存储字段,因为在查询many的数据的时候是通过这个字段进行查询的。
    • name必须在关系模型即Student里面定义(one),studentName在本模型里面定义不定义都可以,如果没有的话会在本模型中创建该字段。

    常见问题:

    • 启动报错:根据报错内容进行相应修改
    • 保存报错:Duplicate entry '******' for key 'PRIMARY',报这个错是因为studentName是唯一键,在将相同name的值赋值给studentName时导致唯一键冲突。其他关系也会有此情况。
  2. O2M关系字段

    配置示例:

       @Field(displayName = "教师关联宠物")
       @Field.one2many
       @Field.Relation(relationFields = {"id"}, referenceFields = {"teacherId"})
       private List<PetShop> studentsCode;

    解析:

    • 在这个一对多关系中,id为本模型的字段,teacherId为PetShop的字段,这个一对多关系通过这两个字段关联起来。
    • 在保存该关联关系时,会将id的值带到teacherId里并保存在PetShop模型中(many)
    • id必须在本模型中定义(one), teacherId在PetShop模型里面定义不定义都可以,如果没有的话会在PetShop模型中创建该字段。

    常见问题:

    • 启动报错:根据报错内容进行相应修改

    • 保存报错:请先保存关联关系模型:如果 id 为自定义字段 与 PetShop进行关联,那么保存关联关系时必须给id 赋值,不然会报错

  3. M2M关系字段

    配置示例1:

    @Field.many2many(through = OrderRelLogistics.MODEL_MODEL, relationFields = {"parentOrderId"}, referenceFields = {"logisticsBillId"})
    @Field.Relation(relationFields = {"id"}, referenceFields = {"id"})
    @Field(displayName = "物流单")
    private List<LogisticsBill> logisticsBillList;

    解析:

    • 在这个多对多关系中,id(左)为本模型的字段,id(右)为PetShop的字段。OrderRelLogistics.MODEL_MODEL为中间表,在保存关联关系时中间表会维护双方的关系字段,id(左)的值写到中间表的parentOrderId字段,id(右)的值写到中间表的logisticsBillId字段。

    常见问题:

    • 保存报错,请先保存关联关系模型:如果id(左)为在本模型自定义的字段,则需要在保存关联关系的时候的时候将该自定义赋值,这样才能正确保存关联关系。

    配置示例2:

    新增TalentTypeEnum

    @Dict(dictionary = TalentTypeEnum.DICTIONARY,displayName = "达人类型")
    public class TalentTypeEnum extends BaseEnum {
    
       public static final String DICTIONARY ="top.TalentTypeEnum";
    
       public final static TalentTypeEnum DOG =create("DOG",1,"狗达人","狗达人");
       public final static TalentTypeEnum CAT =create("CAT",2,"猫达人","猫达人");
    }

    中间表定义

    @Model.model(PetItemRelPetTalent.MODEL_MODEL)
    @Model(displayName = "中间表", summary = "中间表")
    public class PetItemRelPetTalent extends BaseRelation {
    
       public static final String MODEL_MODEL = "top.PetItemRelPetTalent";
    
       @Field.String
       @Field(displayName = "商店ID")
       private String petItemId;
    
       @Field.String
       @Field(displayName = "宠物ID")
       private String petTalentId;
    
       @Field.String
       @Field(displayName = "宠物类型")
       private TalentTypeEnum talentType;
    }

    关系字段定义(关联关系中,使用”##“包括定义常量,这里定义常量"test")

       @Field(displayName = "推荐达人")
       @Field.many2many(
               through = PetItemRelPetTalent.MODEL_MODEL,
               relationFields = {"petItemId"},
               referenceFields = {"petTalentId","talentType"}
       )
       @Field.Relation(relationFields = {"id"}, referenceFields = {"id", "#2#"})
       private List petTalents;

    解析:

    • 在这个多对多的关系中,查询时首先会查当前模型的字段,拿到当前模型的id(左),然后根据条件petItem_id=id(左) 去查中间表,就可以在中间表里查询出多个categoryId,talentType,然后根据条件(id(右), talenttype) IN (categoryId,talentType)查询出关系表PetTalent
    • 注意:talentType字段必须在关系表PetTalent中定义,并和中间表定义的字段talentType保持一致
    • O2M、M2O、M2M关系字段配置问题以及问题排查路径

    常见问题:

    • 报错:需要配置关联模型的关联字段:原因是在PetTalent中没有定义talentType字段

    配置示例3:

       @Field(displayName = "类目")
       @Field.many2many(
               through = MaterialRelCategory.MODEL_MODEL,
               relationFields = {"materialId","type"},
               referenceFields = {"categoryId"}
       )
       @Field.Relation(relationFields = {"id", "#test#"}, referenceFields = {"id"})
       private List categoryList;

    解析:

    • 在这个多对多关系中,查询时首先会查当前模型的字段,拿到当前模型的id(左),然后根据条件material_id=id(左) AND type = test 去查中间表,就可以在中间表里查询出多个categoryId,然后根据条件id(右)IN (categoryId)查询出关系表MaterialCategory
    • O2M、M2O、M2M关系字段配置问题以及问题排查路径
    • 更多使用方式见文档https://doc.oinone.top/oio4/9241.html

Oinone社区 作者:yexiu原创文章,如若转载,请注明出处:https://doc.oinone.top/wen-ti-zhen-duan/15999.html

访问Oinone官网:https://www.oinone.top获取数式Oinone低代码应用平台体验

(1)
yexiu的头像yexiu数式员工
上一篇 2024年8月8日 pm12:55
下一篇 2024年8月10日 pm12:59

相关推荐

  • 工作流工作台无权限排查路径

    现象:用户前端自定义跳转工作流审批页面,提示无权限 排查路径: 5.0版本权限是根据路径进行鉴权的,请求载荷中variables需要携带path路径。 示例:path=/management_center/AuthMenus_RoleAndPermission_SystemPermission如果是用户自定义跳转页面,需要配置sessionPath:,值为url中的path路径 查看debug信息中权限上下文中角色携带的权限是否正确 复制debug信息中的path路径,去权限上下文中搜索查看该路径下所有的权限 ~~~ “getRoleActionPermissionsByViewAction:workbench.WorkBenchWorkflowUserTaskActive:WorkflowMenus_WorkBenchMenu_ActiveUserTaskMenu”: { “630732547466232342”: { “/workflow/WorkflowMenus_WorkBenchMenu_ActiveUserTaskMenu/ACTION#workbench.WorkBenchWorkflowUserTaskActive#workflow_write/ACTION#workflow.WorkflowUserTask#workflow_writeturnon”: 1, “/workflow/WorkflowMenus_WorkBenchMenu_ActiveUserTaskMenu/ACTION#workbench.WorkBenchWorkflowUserTaskActive#workflow_wait/ACTION#workflow.WorkflowUserTask#workflow_agree”: 1, } }, ~~~ 参数介绍: 630732547466232342:角色630732547466232342拥有的所有权限信息 /workflow/WorkflowMenus_WorkBenchMenu_ActiveUserTaskMenu:path路径 /ACTION#workbench.WorkBenchWorkflowUserTaskActive#workflow_write:此path路径下面的ACTION,模型为workbench.WorkBenchWorkflowUserTaskActive的workflow_write动作。 对比无权限页面和以上参数是否对应。可在页面url上查看模型,动作。常见问题有模型不匹配(更换为正常有权限的模型)、角色下无动作权限。

    2024年8月6日
    52500
  • 新增模块不存在

    后端代码新增了一个模块,但在前端看不到新增的模块,主要排查以下几个方面 检查启动参数中是否添加-Plifecycle=INSTALL。 启动工程的yml文件中在pamirs: boot: modules: 中是否添加了该模块 启动工程的pom文件是否依赖该该模块所在包 检查启动工程是否扫描到了该模块所在包

    2024年7月23日
    77500
  • 函数如何跳过权限拦截

    跳过登录直接调用接口 示例: 跳过queryTea的权限验证 @Action(displayName = "queryTea", bindingType = ViewTypeEnum.FORM) @Action.Advanced(type = FunctionTypeEnum.UPDATE) public Teacher queryTea(Teacher data) { } 在yaml文件里面配置上该函数的namespace(模型编码)以及函数名字 pamirs: auth: fun-filter: – namespace: user.PamirsUserTransient fun: login #登录 – namespace: top.Teacher fun: queryTea 不跳过登录直接调用接口 示例: 在yaml文件里面配置上该函数的namespace(模型编码)以及函数名字 pamirs: auth: fun-filter-only-login: #登录后不再校验该函数的权限 – namespace: top.Teacher fun: queryTea 按包设置权限过滤 如何批量跳过权限验证?以上两种方式提供了在yml文件里面配置权限过滤的方式,但如果需要大量过滤权限,配置就变得很繁琐,所以下面主要介绍通过代码扩展的方式去控制权限。 示例: 以下示例通过控制包路径来跳过权限。 继承pro.shushi.pamirs.auth.api.spi.AuthFilterService接口 @Order(88) @Component public class CustomAuthFilterService implements AuthFilterService { public static final String skipClass = "pro.shushi.pamirs.top.core.action"; @Override public Boolean isAccessAction(String model, String name) { //从缓存中取函数 Action cacheAction = PamirsSession.getContext().getExtendCache(ActionCacheApi.class).get(model, name); if (cacheAction instanceof ServerAction) { ServerAction serverAction = (ServerAction) cacheAction; Function function = PamirsSession.getContext().getFunction(serverAction.getModel(), serverAction.getFun()); String clazz = function.getClazz(); //返回true就代表通过验证 if (clazz != null && clazz.startsWith(skipClass)) { return true; } } return null; } } 请求pro.shushi.pamirs.top.core.action路径下的动作可以通过验证。

    2024年8月22日
    82700
  • 树表查不到二级目录

    场景:树表结构查不到二级模型内容,联动配置如下 问题:界面只显示部门,不显示岗位。 已知: 自定义部门代理模型继承了PamirsDepartment @Model.model(DepartmentDoc.MODEL_MODEL) @Model.Advanced(type = ModelTypeEnum.PROXY) @Model(displayName = “部门资料代理模型”, summary = “部门资料代理模型”) public class DepartmentDoc extends PamirsDepartment { public static final String MODEL_MODEL = “top.DepartmentDoc”; @Field.many2one @Field(displayName = “上级部门”) private DepartmentDoc parent; @Field.one2many @Field(displayName = “岗位列表”) private List positionLists; } 自定义岗位代理模型继承了PamirsPosition @Model.model(PositionDoc.MODEL_MODEL) @Model(displayName = “岗位代理模型”, summary = “岗位代理模型”) @Model.Advanced(type = ModelTypeEnum.PROXY) public class PositionDoc extends PamirsPosition { public static final String MODEL_MODEL = “top.PositionDoc”; @Field.many2one @Field(displayName = “上级岗位”) private PositionDoc parent; } 首先查看控制台相应请求 找到请求接口进后端debug,pro.shushi.pamirs.boot.web.action.UiTreeAction#fetchChildren 检查这两个数据是否正常 继续debug可知,在queryWrapper中使用departmentCode没有查询出数据,这时候回看模型定义,发现岗位列表中没有定义关联字段,导致没有查出数据。pro.shushi.pamirs.boot.web.manager.tree.UiTreeRelationQueryManager#_fetchIsLeaf 解决:在模型配置中添加关系字段@Field.Relation(relationFields = {"code"}, referenceFields = {"departmentCode"}),并和父类中的关系字段保持一致 部门代理模型: @Model.model(DepartmentDoc.MODEL_MODEL) @Model.Advanced(type = ModelTypeEnum.PROXY) @Model(displayName = "部门资料代理模型", summary = "部门资料代理模型") public class DepartmentDoc extends PamirsDepartment { public static final String MODEL_MODEL = "top.DepartmentDoc"; @Field.many2one @Field.Relation(relationFields = {"parentCode"}, referenceFields = {"code"}) @Field(displayName = "上级部门") private DepartmentDoc parent; @Field.one2many @Field.Relation(relationFields = {"code"}, referenceFields = {"departmentCode"}) @Field(displayName = "岗位列表") private List<PositionDoc> positionLists; } 岗位代理模型 @Model.model(PositionDoc.MODEL_MODEL) @Model(displayName = "岗位代理模型", summary = "岗位代理模型") @Model.Advanced(type = ModelTypeEnum.PROXY) public class PositionDoc extends PamirsPosition { public static final String MODEL_MODEL = "top.PositionDoc"; @Field.many2one @Field.Relation(relationFields = {"departmentCode"}, referenceFields = {"code"}) @Field(displayName = "上级岗位") private PositionDoc parent; }

    2024年7月23日
    51500
  • 保存多值字段SQL执行报错

    定义多值类型时,字段类型应该设置为List类型。 @Field.String @Field(displayName ="经费证明", multi = true, serialize = Field.serialize.JSON) private List<String> matchFund; 场景复现

    2024年8月30日
    56200

Leave a Reply

登录后才能评论