如何首先使用现有数据库实现代码

时间:2014-04-21 12:59:14

标签: entity-framework ef-code-first

我正在使用entityframework 5,代码优先模型和现有数据库。我正在实现存储库模式。我有一个BaseEntity类,如下所示:

 public abstract partial class BaseEntity
    {
        /// <summary>
        /// Gets or sets the entity identifier
        /// </summary>
        public virtual int Id { get; set; }

        public override bool Equals(object obj)
        {
            return Equals(obj as BaseEntity);
        }

        private static bool IsTransient(BaseEntity obj)
        {
            return obj != null && Equals(obj.Id, default(int));
        }

        private Type GetUnproxiedType()
        {
            return GetType();
        }

        public virtual bool Equals(BaseEntity other)
        {
            if (other == null)
                return false;

            if (ReferenceEquals(this, other))
                return true;

            if (!IsTransient(this) &&
                !IsTransient(other) &&
                Equals(Id, other.Id))
            {
                var otherType = other.GetUnproxiedType();
                var thisType = GetUnproxiedType();
                return thisType.IsAssignableFrom(otherType) ||
                        otherType.IsAssignableFrom(thisType);
            }

            return false;
        }

        public override int GetHashCode()
        {
            if (Equals(Id, default(int)))
                return base.GetHashCode();
            return Id.GetHashCode();
        }

        public static bool operator ==(BaseEntity x, BaseEntity y)
        {
            return Equals(x, y);
        }

        public static bool operator !=(BaseEntity x, BaseEntity y)
        {
            return !(x == y);
        }
        protected virtual void SetParent(dynamic child)
        {

        }
        protected virtual void SetParentToNull(dynamic child)
        {

        }

        protected void ChildCollectionSetter<T>(ICollection<T> collection, ICollection<T> newCollection) where T : class
        {
            if (CommonHelper.OneToManyCollectionWrapperEnabled)
            {
                collection.Clear();
                if (newCollection != null)
                    newCollection.ToList().ForEach(x => collection.Add(x));
            }
            else
            {
                collection = newCollection;
            }
        }


        protected ICollection<T> ChildCollectionGetter<T>(ref ICollection<T> collection, ref ICollection<T> wrappedCollection) where T : class
        {
            return ChildCollectionGetter(ref collection, ref wrappedCollection, SetParent, SetParentToNull);
        }

        protected ICollection<T> ChildCollectionGetter<T>(ref ICollection<T> collection, ref ICollection<T> wrappedCollection, Action<dynamic> setParent, Action<dynamic> setParentToNull) where T : class
        {
            if (CommonHelper.OneToManyCollectionWrapperEnabled)
                return wrappedCollection ?? (wrappedCollection = (collection ?? (collection = new List<T>())).SetupBeforeAndAfterActions(setParent, SetParentToNull));
            return collection ?? (collection = new List<T>());
        }
    }

现在我有一个表Customer,它有CustomerId作为主键。我应该如何映射IdE为BaseEntity的字段。如果我有一个复合键,我应该如何将它映射到BaseEntity ID。 请帮助我。

1 个答案:

答案 0 :(得分:0)

确保将DBContext的初始化设置为false:

context.Database.Initialize(假);

这是一篇关于代码的数据库初始化程序的好文章:

http://www.codeguru.com/csharp/article.php/c19999/Understanding-Database-Initializers-in-Entity-Framework-Code-First.htm