Entity Framework中的持久化
使用Entity Framework将实体持久化(保存)到数据库有两种场景:连接场景和断开连接场景。
连接场景
所谓连接场景指的是:实体被DbContext所跟踪,实体被添加在DbContext中的DbSet集合中。
在连接场景中,上下文类的同一个实例(从DbContext派生)用于检索和保存实体。它在生命周期内跟踪所有实体。这在具有本地数据库或同一网络上的数据库的windows应用程序中非常有用。
优点:
执行迅速。
上下文跟踪所有实体,并在实体发生更改时自动设置适当的状态。
缺点:
上下文保持活动状态,因此与数据库的连接保持打开状态。
占用更多的资源。
断开连接的场景
所谓断开连接场景指的是:实体未被DbContext所跟踪,该实体就是一个普通的POCO。
在断开连接的场景中,上下文的不同实例用于检索实体并将实体保存到数据库中。检索数据后将释放上下文的实例,并创建一个新实例以将实体保存到数据库中。
断开连接的场景很复杂,因为上下文的实例不跟踪实体,所以必须在使用SaveChanges()保存实体之前为每个实体设置适当的状态。在上图中,应用程序使用Context 1检索实体图,然后应用程序使用Context 2执行一些CUD(创建、更新、删除)操作。Context 2不知道在这个场景中实体图上执行了什么操作。
这在web应用程序或带有远程数据库的应用程序中非常有用。
优点:
与连接的场景相比,使用更少的资源。
没有打开与数据库的连接。
缺点:
在保存之前,需要为每个实体设置适当的状态。
执行速度比连接场景慢。
参考
https://www.entityframeworktutorial.net/
https://msdn.microsoft.com/