问题描述
NBear中设置单向的组合关系存在的疑问(使用NBear3.7.2的ORM框架,如需源码请联系hillfree#gmail.com)问题描述:涉及两个业务对象:User(用户)和UserType(用户类型);UserType作为系统的基础信息,可能会增加,重命名,甚至删除。User接口中包含UserType的对象作为一个成员。与Tutorial中的一对一关联不同。UserType不需要知道User的存在,即User和UserType是单向的组合关联。User和UserType的接口定义如表1,表2:注:一些不必要的字段被省略到此为止,一切都运行的很好。单向组合关联,级联更新等。-------问题:当外键需要关联到UserType的Code(编码)字段时出错-------因为用ID作外键,在多处部署的基础信息维护时,用户觉得不够方便,希望能用Code作为外键关联,这样用户只要在UserType中新建对应编码值的对象即可。因此,把User接口定义修改为表3的样子,但是gateway.cs报错,因为在gateway中要把一个Guid类型赋值给Code字段。考虑到可能是主键关系的问题,把UserType的ID字段去掉,将Code作为主键,即修改为表4的样子,可是问题依旧。因此,疑问如下:如何建立一个单向组合关系的外键关联,而且对应实体的主键为String类型?附件中带有工程源码,供参考,谢谢。表1:User接口定义publicinterfaceUser:Entity{[PrimaryKey]GuidID{get;set;}stringName{get;set;}[FkQuery("ID",Contained=true,LazyLoad=true)]UserTypeType{get;set;}}表2:UserType接口定义publicinterfaceUserType:Entity{[PrimaryKey]GuidID//主键{get;set;}stringCode//类型编码{get;set;}stringName//类型名称{get;set;}}表3:修改后的User接口定义publicinterfaceUser:Entity{[PrimaryKey]GuidID{get;set;}stringName{get;set;}[FkQuery("Code",Contained=true,LazyLoad=true)]//仅此地方将ID改为CodeUserTypeType{get;set;}}表4:修改后UserType接口定义publicinterfaceUserType:Entity{[PrimaryKey]stringCode//类型编码{get;set;}stringName//类型名称{get;set;}}
解决方案
解决方案二:
沒用過NBear,幫頂
解决方案三:
这么高分帮你up
解决方案四:
帮顶了先。
解决方案五:
up】
解决方案六:
谢谢楼上的兄弟帮顶。