I am adding an entity to my database like so:
public TEntity Add(TEntity entity)
{
     return (TEntity)_database.Set<TEnti开发者_StackOverflow社区ty>().Add(entity);
}
However, the DbSet.Add method isn't returning the newly added entity with the Id etc, it is simply returning the object I passed in to my Add method.
Should it be passing me back the complete new entity including Id, or is it not possible to get the Id before SaveChanges() is called?
All the call to Add() is doing is effectively registering it with the data context so that the entity can be tracked. No actual operation is done against the database at this time until (as you rightly mention) you call SaveChanges().
I'm assuming that you're using automatically-generated Ids in your table; in this case, it's the database engine which will generate that Id when the record is inserted, and Entity Framework will read this back and populate your entity for you.
So, to confirm your suspicions, no - it's not possible to get the Id before SaveChanges() is called in this case.
Hope this helps!
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论