Код Entity Framework первый файл базы данных не был создан в данных приложения, но запросы работают


Мои модели для моего блога:

namespace AlexPeta_2.Models
{
    public class Article
    {
        public int ArticleId { get; set; }
        public string Title { get; set; }
        public string Text { get; set; }
        public char Published { get; set; }
        public DateTime CreatedDate { get; set; }
        public char AllowComment { get; set; }

        public virtual ICollection<Tag> Tags { get; set; }
        public virtual ICollection<Comment> Comments { get; set; }
    }
}

namespace AlexPeta_2.Models
{
    public class Comment
    {
        public int CommentId { get; set; }
        public string Name { get; set; }
        public string Email { get; set; }
        public string HomePage { get; set; }
        public string Comm { get; set; }
        public DateTime CreatedDate { get; set; }
    }
}

namespace AlexPeta_2.Models
{
    public class Tag
    {
        public int TagId { get; set; }
        public string TagName { get; set; }
        public virtual ICollection<Article> Articles { get; set; }
    }
}

Вот мои dbsets:

public class BlogContext : DbContext
{
    public DbSet<Article> Articles { get; set; }
    public DbSet<Tag> Tags { get; set; }
    public DbSet<Comment> Comments { get; set; }
}

Вот мой инициализатор:

public class BlogInitializer : DropCreateDatabaseIfModelChanges<BlogContext>
    {
        protected override void Seed(BlogContext context)
        {

            List<Tag> tags = new List<Tag>
            {
                new Tag { TagId = 1, TagName = "Javascript" },
                new Tag { TagId = 2, TagName = "Bodybuilding" },
                new Tag { TagId = 3, TagName = "Uncategorised" },
                new Tag { TagId = 4, TagName = "CSS" },
                new Tag { TagId = 5, TagName = "HTML/XHTML" },
                new Tag { TagId = 6, TagName = "APEX" },
                new Tag { TagId = 7, TagName = "PL/SQL" },
                new Tag { TagId = 8, TagName = "Personal" },
                new Tag { TagId = 9, TagName = "ASP" },
                new Tag { TagId = 10, TagName = "MVC" },
                new Tag { TagId = 11, TagName = "C#" },
                new Tag { TagId = 12, TagName = "Snowboarding" }
            };
            tags.ForEach(t => context.Tags.Add(t));
            context.SaveChanges();
        }
    }

Самое смешное : я запустил приложение без строки подключения в webconfig, оно работает нормально , я вижу все мои теги в контроллере, но нет файла базы данных в APP_DATA ?? Как же так вышло? или что случилось?

2   2   2012-02-09 13:51:58

2 ответа:

Если строка подключения не указана, EF-код сначала создает базу данных с учетными данными пользователя (windows) на локальном экземпляре SQLExpress. То же самое можно проверить с помощью SQL Server Management Studio Express и входа в локальный экземпляр.

Алекс,

В connectionString на самом деле происходит автоматически (т. е. условно) от DbContext, который (в вашем случае экземпляр класса blogcontext), так что вы найдете что-либо внутри sqlexpress или sqlcompact, что вы будете иметь новую БД с именем, что ваш DbContext, который имеет.

Удачи.