DbContext.SaveChangesAsync 方法
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
重载
SaveChangesAsync(Boolean, CancellationToken) |
将在此上下文中所做的所有更改保存到数据库。 |
SaveChangesAsync(CancellationToken) |
将在此上下文中所做的所有更改保存到数据库。 |
SaveChangesAsync(Boolean, CancellationToken)
将在此上下文中所做的所有更改保存到数据库。
public virtual System.Threading.Tasks.Task<int> SaveChangesAsync (bool acceptAllChangesOnSuccess, System.Threading.CancellationToken cancellationToken = default);
abstract member SaveChangesAsync : bool * System.Threading.CancellationToken -> System.Threading.Tasks.Task<int>
override this.SaveChangesAsync : bool * System.Threading.CancellationToken -> System.Threading.Tasks.Task<int>
Public Overridable Function SaveChangesAsync (acceptAllChangesOnSuccess As Boolean, Optional cancellationToken As CancellationToken = Nothing) As Task(Of Integer)
参数
- acceptAllChangesOnSuccess
- Boolean
指示在更改成功发送到数据库后是否 AcceptAllChanges() 调用 。
- cancellationToken
- CancellationToken
等待 CancellationToken 任务完成时要观察的 。
返回
表示异步保存操作的任务。 任务结果包含写入数据库的状态条目数。
例外
保存到数据库时遇到错误。
保存到数据库时遇到并发冲突。 如果在保存过程中影响意外的行数,则会发生并发冲突。 这通常是因为数据库中的数据自加载到内存后已修改。
注解
此方法将自动调用 DetectChanges() 以发现实体实例的任何更改,然后再保存到基础数据库。 这可以通过 禁用 AutoDetectChangesEnabled。
Entity Framework Core 不支持在同一 DbContext 实例上运行多个并行操作。 这包括异步查询的并行执行以及从多个线程进行的任何显式并发使用。 因此,请始终立即等待异步调用,或者对并行执行的操作使用单独的 DbContext 实例。 有关详细信息和示例 ,请参阅避免 DbContext 线程问题 。
有关详细信息和示例,请参阅 在 EF Core 中保存数据 。
适用于
SaveChangesAsync(CancellationToken)
将在此上下文中所做的所有更改保存到数据库。
public virtual System.Threading.Tasks.Task<int> SaveChangesAsync (System.Threading.CancellationToken cancellationToken = default);
abstract member SaveChangesAsync : System.Threading.CancellationToken -> System.Threading.Tasks.Task<int>
override this.SaveChangesAsync : System.Threading.CancellationToken -> System.Threading.Tasks.Task<int>
Public Overridable Function SaveChangesAsync (Optional cancellationToken As CancellationToken = Nothing) As Task(Of Integer)
参数
- cancellationToken
- CancellationToken
等待 CancellationToken 任务完成时要观察的 。
返回
表示异步保存操作的任务。 任务结果包含写入数据库的状态条目数。
例外
保存到数据库时遇到错误。
保存到数据库时遇到并发冲突。 如果在保存过程中影响意外的行数,则会发生并发冲突。 这通常是因为数据库中的数据自加载到内存后已修改。
注解
此方法将自动调用 DetectChanges() 以发现实体实例的任何更改,然后再保存到基础数据库。 这可以通过 禁用 AutoDetectChangesEnabled。
Entity Framework Core 不支持在同一 DbContext 实例上运行多个并行操作。 这包括异步查询的并行执行以及从多个线程进行的任何显式并发使用。 因此,请始终立即等待异步调用,或者对并行执行的操作使用单独的 DbContext 实例。 有关详细信息和示例 ,请参阅避免 DbContext 线程问题 。
有关详细信息和示例,请参阅 在 EF Core 中保存数据 。