Getting an error while “update-database” command is running: There is already an object named '…' in...











up vote
2
down vote

favorite












I have a few EF Core models:



abstract class Weapon {
public int Id { get; set; }
public string Name { get; set; }
}

class Axe : Weapon {
}

class Sword : Weapon {
}

class GameDbContext : DbContext {
public DbSet<Weapon> Weapons { get; set; }

public GameDbContext(DbContextOptions options) : base(options){
this.Database.EnsureCreated();
}

protected override void OnModelCreating(ModelBuilder modelBuilder) {
base.OnModelCreating(modelBuilder);

this.SetModelsConfigurations(modelBuilder);

modelBuilder.Entity<Axe> ().HasBaseType<Weapon>();
modelBuilder.Entity<Sword>().HasBaseType<Weapon>();
}
}


When I run "add-migration" command everything is Ok. But when I run "update-database" command, I get an error:




There is already an object named 'Weapons' in the database.




This DB wasn't created. Why do I get this error? Please explain to me how DB models should be configured.










share|improve this question






















  • Only use Migrate or MigrateAsync. This will already create a database. The CreateDatabase command itself will create a database according to it's current model, disregarding your migration logic.
    – Silvermind
    Nov 19 at 16:59












  • @Silvermind Is that a command? Or Method?
    – Evgeniy Miroshnichenko
    Nov 19 at 17:02






  • 1




    @Silvermind ( I see that problem was with method: this.Database.EnsureCreated(). "update-databes" command was done after this method was deleted.
    – Evgeniy Miroshnichenko
    Nov 19 at 17:16












  • I'm sorry. I thought you were using migrations in code. If you're using the cli, you should just be able to use update-database according to the docs
    – Silvermind
    Nov 19 at 17:16












  • Ah, thats why I mixed them up. Yeah I meant EnsureCreated instead of CreateDatabase. Don't use that command with migrations. ;)
    – Silvermind
    Nov 19 at 17:18

















up vote
2
down vote

favorite












I have a few EF Core models:



abstract class Weapon {
public int Id { get; set; }
public string Name { get; set; }
}

class Axe : Weapon {
}

class Sword : Weapon {
}

class GameDbContext : DbContext {
public DbSet<Weapon> Weapons { get; set; }

public GameDbContext(DbContextOptions options) : base(options){
this.Database.EnsureCreated();
}

protected override void OnModelCreating(ModelBuilder modelBuilder) {
base.OnModelCreating(modelBuilder);

this.SetModelsConfigurations(modelBuilder);

modelBuilder.Entity<Axe> ().HasBaseType<Weapon>();
modelBuilder.Entity<Sword>().HasBaseType<Weapon>();
}
}


When I run "add-migration" command everything is Ok. But when I run "update-database" command, I get an error:




There is already an object named 'Weapons' in the database.




This DB wasn't created. Why do I get this error? Please explain to me how DB models should be configured.










share|improve this question






















  • Only use Migrate or MigrateAsync. This will already create a database. The CreateDatabase command itself will create a database according to it's current model, disregarding your migration logic.
    – Silvermind
    Nov 19 at 16:59












  • @Silvermind Is that a command? Or Method?
    – Evgeniy Miroshnichenko
    Nov 19 at 17:02






  • 1




    @Silvermind ( I see that problem was with method: this.Database.EnsureCreated(). "update-databes" command was done after this method was deleted.
    – Evgeniy Miroshnichenko
    Nov 19 at 17:16












  • I'm sorry. I thought you were using migrations in code. If you're using the cli, you should just be able to use update-database according to the docs
    – Silvermind
    Nov 19 at 17:16












  • Ah, thats why I mixed them up. Yeah I meant EnsureCreated instead of CreateDatabase. Don't use that command with migrations. ;)
    – Silvermind
    Nov 19 at 17:18















up vote
2
down vote

favorite









up vote
2
down vote

favorite











I have a few EF Core models:



abstract class Weapon {
public int Id { get; set; }
public string Name { get; set; }
}

class Axe : Weapon {
}

class Sword : Weapon {
}

class GameDbContext : DbContext {
public DbSet<Weapon> Weapons { get; set; }

public GameDbContext(DbContextOptions options) : base(options){
this.Database.EnsureCreated();
}

protected override void OnModelCreating(ModelBuilder modelBuilder) {
base.OnModelCreating(modelBuilder);

this.SetModelsConfigurations(modelBuilder);

modelBuilder.Entity<Axe> ().HasBaseType<Weapon>();
modelBuilder.Entity<Sword>().HasBaseType<Weapon>();
}
}


When I run "add-migration" command everything is Ok. But when I run "update-database" command, I get an error:




There is already an object named 'Weapons' in the database.




This DB wasn't created. Why do I get this error? Please explain to me how DB models should be configured.










share|improve this question













I have a few EF Core models:



abstract class Weapon {
public int Id { get; set; }
public string Name { get; set; }
}

class Axe : Weapon {
}

class Sword : Weapon {
}

class GameDbContext : DbContext {
public DbSet<Weapon> Weapons { get; set; }

public GameDbContext(DbContextOptions options) : base(options){
this.Database.EnsureCreated();
}

protected override void OnModelCreating(ModelBuilder modelBuilder) {
base.OnModelCreating(modelBuilder);

this.SetModelsConfigurations(modelBuilder);

modelBuilder.Entity<Axe> ().HasBaseType<Weapon>();
modelBuilder.Entity<Sword>().HasBaseType<Weapon>();
}
}


When I run "add-migration" command everything is Ok. But when I run "update-database" command, I get an error:




There is already an object named 'Weapons' in the database.




This DB wasn't created. Why do I get this error? Please explain to me how DB models should be configured.







c# asp.net entity-framework ef-core-2.1






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 19 at 16:57









Evgeniy Miroshnichenko

416617




416617












  • Only use Migrate or MigrateAsync. This will already create a database. The CreateDatabase command itself will create a database according to it's current model, disregarding your migration logic.
    – Silvermind
    Nov 19 at 16:59












  • @Silvermind Is that a command? Or Method?
    – Evgeniy Miroshnichenko
    Nov 19 at 17:02






  • 1




    @Silvermind ( I see that problem was with method: this.Database.EnsureCreated(). "update-databes" command was done after this method was deleted.
    – Evgeniy Miroshnichenko
    Nov 19 at 17:16












  • I'm sorry. I thought you were using migrations in code. If you're using the cli, you should just be able to use update-database according to the docs
    – Silvermind
    Nov 19 at 17:16












  • Ah, thats why I mixed them up. Yeah I meant EnsureCreated instead of CreateDatabase. Don't use that command with migrations. ;)
    – Silvermind
    Nov 19 at 17:18




















  • Only use Migrate or MigrateAsync. This will already create a database. The CreateDatabase command itself will create a database according to it's current model, disregarding your migration logic.
    – Silvermind
    Nov 19 at 16:59












  • @Silvermind Is that a command? Or Method?
    – Evgeniy Miroshnichenko
    Nov 19 at 17:02






  • 1




    @Silvermind ( I see that problem was with method: this.Database.EnsureCreated(). "update-databes" command was done after this method was deleted.
    – Evgeniy Miroshnichenko
    Nov 19 at 17:16












  • I'm sorry. I thought you were using migrations in code. If you're using the cli, you should just be able to use update-database according to the docs
    – Silvermind
    Nov 19 at 17:16












  • Ah, thats why I mixed them up. Yeah I meant EnsureCreated instead of CreateDatabase. Don't use that command with migrations. ;)
    – Silvermind
    Nov 19 at 17:18


















Only use Migrate or MigrateAsync. This will already create a database. The CreateDatabase command itself will create a database according to it's current model, disregarding your migration logic.
– Silvermind
Nov 19 at 16:59






Only use Migrate or MigrateAsync. This will already create a database. The CreateDatabase command itself will create a database according to it's current model, disregarding your migration logic.
– Silvermind
Nov 19 at 16:59














@Silvermind Is that a command? Or Method?
– Evgeniy Miroshnichenko
Nov 19 at 17:02




@Silvermind Is that a command? Or Method?
– Evgeniy Miroshnichenko
Nov 19 at 17:02




1




1




@Silvermind ( I see that problem was with method: this.Database.EnsureCreated(). "update-databes" command was done after this method was deleted.
– Evgeniy Miroshnichenko
Nov 19 at 17:16






@Silvermind ( I see that problem was with method: this.Database.EnsureCreated(). "update-databes" command was done after this method was deleted.
– Evgeniy Miroshnichenko
Nov 19 at 17:16














I'm sorry. I thought you were using migrations in code. If you're using the cli, you should just be able to use update-database according to the docs
– Silvermind
Nov 19 at 17:16






I'm sorry. I thought you were using migrations in code. If you're using the cli, you should just be able to use update-database according to the docs
– Silvermind
Nov 19 at 17:16














Ah, thats why I mixed them up. Yeah I meant EnsureCreated instead of CreateDatabase. Don't use that command with migrations. ;)
– Silvermind
Nov 19 at 17:18






Ah, thats why I mixed them up. Yeah I meant EnsureCreated instead of CreateDatabase. Don't use that command with migrations. ;)
– Silvermind
Nov 19 at 17:18



















active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














 

draft saved


draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53379376%2fgetting-an-error-while-update-database-command-is-running-there-is-already-an%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown






























active

oldest

votes













active

oldest

votes









active

oldest

votes






active

oldest

votes
















 

draft saved


draft discarded



















































 


draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53379376%2fgetting-an-error-while-update-database-command-is-running-there-is-already-an%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Wiesbaden

Marschland

Dieringhausen