首页 新闻 会员 周边

NBear中设置单向的组合关系存在的疑问

0
悬赏园豆:100

NBear中设置单向的组合关系存在的疑问

(使用NBear3.7.2的ORM框架,如需源码请联系hillfree#gmail.com)

问题描述:

(1) 涉及两个业务对象:User(用户)和UserType(用户类型);UserType作为系统的基础信息,可能会增加,重命名,甚至删除。

(2) User接口中包含UserType的对象作为一个成员。与Tutorial中的一对一关联不同。UserType不需要知道User的存在,即User和UserType是单向的组合关联。

(3) User和UserType的接口定义如表1,表2:注:一些不必要的字段被省略

(4) 到此为止,一切都运行的很好。单向组合关联,级联更新等。

(1) ------- 问题:当外键需要关联到UserType的Code(编码)字段时出错-------

(2) 因为用ID作外键,在多处部署的基础信息维护时,用户觉得不够方便,希望能用Code作为外键关联,这样用户只要在UserType中新建对应编码值的对象即可。

(3) 因此,把User接口定义修改为表3的样子,但是gateway.cs报错,因为在gateway中要把一个Guid类型赋值给Code字段。

(4) 考虑到可能是主键关系的问题,把UserType的ID字段去掉,将Code作为主键,即修改为表4的样子,可是问题依旧。

因此,疑问如下:

如何建立一个单向组合关系的外键关联,而且对应实体的主键为String类型?

附件中带有工程源码,供参考,谢谢。

表1:User接口定义

    public interface User : Entity

    {

        [PrimaryKey]

        Guid ID

        {

            get;

            set;

        }

        string Name

        {

            get;

            set;

        }

        [FkQuery("ID", Contained=true, LazyLoad=true)]

        UserType Type

        {

            get;

            set;

        }

    }

表2:UserType接口定义

    public interface UserType : Entity

    {

        [PrimaryKey]

        Guid ID // 主键

        {

            get;

            set;

        }

        string Code   // 类型编码

        {

            get;

            set;

        }

        string Name  // 类型名称

        {

            get;

            set;

        }

}

表3:修改后的User接口定义

    public interface User : Entity

    {

        [PrimaryKey]

        Guid ID

        {

            get;

            set;

        }

        string Name

        {

            get;

            set;

        }

        [FkQuery("Code", Contained=true, LazyLoad=true)] // 仅此地方将ID改为Code

        UserType Type

        {

            get;

            set;

        }

    }

表4:修改后UserType接口定义

    public interface UserType : Entity

    {

        [PrimaryKey]

        string Code   // 类型编码

        {

            get;

            set;

        }

        string Name  // 类型名称

        {

            get;

            set;

        }

}

hgdfr的主页 hgdfr | 初学一级 | 园豆:105
提问于:2009-05-04 12:01
< >
分享
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册