Ir ao conteúdo
  • Cadastre-se

Entity framework 6: erro entre contextos


Posts recomendados

Estou usando dois contextos: Um para o Asp.Net Identity e outro para a minha aplicação.

Criei a entidade "Usuario" para representar a tabela "AspNetUsers" do Identity, colocando nela todas as propriedades que tem na tabela "AspNetUsers".

Através do Fluent Api mapeei a entidade "Usuario" da seguinte forma:

 

public class UsuarioConfig : EntityTypeConfiguration<Usuario>

{

          public UsuarioConfig()

          {

                    ToTable("AspNetUsers");

 

                    HasKey(x => x.Id);

 

                    Property(x => x.Nome)

                                .HasMaxLength(100)

                                .IsRequired();

 

                    Property(x => x.Email)

                                .HasMaxLength(100)

                                .IsRequired();

 

                    Property(x => x.UserName)

                                .HasMaxLength(100)

                                .IsRequired();

          }

}

 

E depois adicionei ela no "OnModelCreating()" do contexto da minha aplicação:

 

protected override void OnModelCreating(DbModelBuilder modelBuilder)

{

          base.OnModelCreating(modelBuilder);

          modelBuilder.Configurations.Add(new UsuarioConfig());

          ...

}

 

E no contexto do Identity coloquei essa mesma configuração diretamente no "OnModelCreating()":

 

public class ApplicationDbContext : IdentityDbContext<ApplicationUser, ApplicationRole, int, ApplicationUserLogin, ApplicationUserRole, ApplicationUserClaim>, IDisposable

{

          public ApplicationDbContext() : base("DefaultConnection") { }

 

          protected override void OnModelCreating(DbModelBuilder modelBuilder)

          {

                    base.OnModelCreating(modelBuilder);

 

                    modelBuilder.Entity<ApplicationUser>()

                                        .ToTable("AspNetUsers");

 

                    modelBuilder.Entity<ApplicationUser>()

                                        .HasKey(x => x.Id);

 

                    modelBuilder.Entity<ApplicationUser>()

                                        .Property(x => x.Nome)

                                        .IsRequired()

                                        .HasMaxLength(100);

 

                    modelBuilder.Entity<ApplicationUser>()

                                        .Property(x => x.Email)

                                        .IsRequired()

                                        .HasMaxLength(100);

 

                    modelBuilder.Entity<ApplicationUser>()

                                        .Property(x => x.UserName)

                                        .HasMaxLength(100)

                                        .IsRequired();

          }

 

          public static ApplicationDbContext Create()

          {

                    return new ApplicationDbContext();

          }

}

 

Mas ao dar o Update-Database, o EF6 reclama que já existe a tabela "AspNetUsers", mas eu não queria que ele tentasse criar a tabela, mas somente referenciá-la ou que atualizasse ela. Tem alguma forma de dizer ao EF6 para que ele não tente criar a tabela novamente?

Link para o comentário
Compartilhar em outros sites

Visitante
Este tópico está impedido de receber novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...

Ebook grátis: Aprenda a ler resistores e capacitores!

EBOOK GRÁTIS!

CLIQUE AQUI E BAIXE AGORA MESMO!