日期:2014-05-17  浏览次数:20412 次

关于实体(不是表)之间的联系的问题
现在有两张表,对于有两个实体,用户表和帖子表
那么帖子表中有一个作者ID的字段,现在我想在帖子(Post)实体里面加一个用户(Member)类型的字段
也就是
C# code

public class Post{
         public Member author
}


这样来表示帖子的作者,现在有个问题,我如何建立这两个实体之间的关联呢?
可以通过作者ID的字段来取得帖子的作者,但在什么时候怎么样把这个作者实体赋值给author呢?


------解决方案--------------------
Member做属性,set中通过作者id赋值 author
------解决方案--------------------
刚那个有问题。重新给你发个
C# code
/*
    此对象由数据设计工具生成
*/
using System;
using System.Collections;
using System.Collections.Generic;
using Ufida.T.EAP.Domains;
using Ufida.T.EAP.Domains.Test;              

namespace Ufida.T.EAP.Domains.Test
{
    partial class Post
    {
        private object iDAuthor;
      /// <summary>
        /// iDAuthor  
      /// </summary>
        public object IDAuthor
      {
          get { return iDAuthor; }
        set {

            iDAuthor = value;
               
            }
      }
        private Member author;
      /// <summary>
      /// Member  关联关系对象
      /// </summary>
        public Member Author
      {
          get { return author; }
        set {

            author = value;
             
            }
      }
     

    }
}

------解决方案--------------------
AuthorID和author(实体)分别作为Member实体的两个属性
在author的Get里面对Author赋值,先判断this.AuthorID有没有值,有值就取出来给Author的赋值,没有就给赋null值
------解决方案--------------------
get 滴时候查询,晚加载。set早加载有点浪费

为了保证查询效率,逻辑内部需要维护一个db的视图。

不然每次get都重新执行一条sql语句都太不划算了