pojia

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

有这么一个领域类
 public class Task    {
        private Project project;
        /// <summary>
        /// 项目
        /// int
        /// </summary>
        [BelongsTo("Project")]
        public Project Project
        {
            get { return project; }
            set { project = value; }
        }
        private IList childrens;
        [HasMany(typeof(Task), Table = "Task", ColumnKey = "ParentTask")]
        public IList Childrens
        {
            get { return childrens; }
            set { childrens = value; }
        }
        private Task parentTask;
        /// <summary>
        /// 父任务
        /// </summary>
        [BelongsTo("ParentTask")]
        public Task ParentTask
        {
            get { return parentTask; }
            set { parentTask = value; }
        }
       private IList members;
        [HasMany(typeof(Member), Table = "Member", ColumnKey = "Task")]
        public IList Members
        {
            get { return members; }
            set { members= value; }
        }

}
这里我关注 private IList childrens;,,就是因为有这样一个关系存在,当Task在做更新(update)时候,除了发生本身的一个update外,,还会根据此关系发生'UPDATE Task SET ParentTask = null WHERE ParentTask = @p0', N'@p0 int', @p0 = 327681,,,这是因为task与自己的子task有一对多关系!!!

以上是主外键在一个表时,,当主外在不同表中时,,比如上面的一个任务对应多个成员时,在更新任务后,也会紧紧跟一句生'UPDATE Member SET Task = null WHERE Task = @p0', N'@p0 int', @p0 = 327643,

==================
注意:
但是对于外键所在对象做更新时候,,,只更新自己,与其他对象不在发生任何联系

posted on 2007-08-10 17:12  破甲  阅读(154)  评论(0编辑  收藏  举报