Use of Include with async await

后端 未结 2 1647
自闭症患者
自闭症患者 2020-12-03 20:36

I have an EF query in which I am returning an \'Item\' by it\'s unique identifier. I\'m using the scaffolded controller provided by MVC and this works ok, but now I want it

相关标签:
2条回答
  • 2020-12-03 21:04

    Followed by @Anthony and @Korayem answer, I recommend to do as below for safer code.

    Item item = await db.Items.Include(o => o.Tags).FirstOrDefaultAsync(i => i.Id == id);
    
    if(item == default(Item))
        return NotFound();
    
    0 讨论(0)
  • 2020-12-03 21:23

    Find() and FindAsync() are methods on type DbSet (which is what db.Items is). Include() returns a DbQuery object, which is why FindAsync() is not available. Use SingleOrDefaultAsync() to do the same thing as FindAsync() (the difference is it will go straight to the database and won't look in the context to see if the entity exists first)...

    Item item = await db.Items.Include("Tags").SingleOrDefaultAsync(i => i.Id == id);
    
    0 讨论(0)
提交回复
热议问题