Class CommerceDbContext
- Namespace
- Rescope.Commerce.Core.Persistence
- Assembly
- Rescope.Commerce.Core.dll
public class CommerceDbContext : DbContext, IInfrastructure<IServiceProvider>, IDbContextDependencies, IDbSetCache, IDbContextPoolable, IResettableService, IDisposable, IAsyncDisposable
- Inheritance
-
CommerceDbContext
- Implements
- Inherited Members
Constructors
CommerceDbContext(DbContextOptions<CommerceDbContext>)
public CommerceDbContext(DbContextOptions<CommerceDbContext> options)
Parameters
options
DbContextOptions<CommerceDbContext>
Properties
Basket
public required DbSet<Basket> Basket { get; set; }
Property Value
BasketLineItems
public required DbSet<BasketLineItem> BasketLineItems { get; set; }
Property Value
Countries
public required DbSet<Country> Countries { get; set; }
Property Value
Currencies
public required DbSet<Currency> Currencies { get; set; }
Property Value
OrderLineItems
public required DbSet<OrderLineItem> OrderLineItems { get; set; }
Property Value
OrderNotificationLogs
public required DbSet<OrderNotificationLog> OrderNotificationLogs { get; set; }
Property Value
OrderPaymentLogs
public required DbSet<OrderPaymentLog> OrderPaymentLogs { get; set; }
Property Value
Orders
public required DbSet<Order> Orders { get; set; }
Property Value
PaymentMethods
public required DbSet<PaymentMethod> PaymentMethods { get; set; }
Property Value
ShippingMethods
public required DbSet<ShippingMethod> ShippingMethods { get; set; }
Property Value
Stock
public required DbSet<Stock> Stock { get; set; }
Property Value
Stores
public required DbSet<Store> Stores { get; set; }
Property Value
TaxRates
public required DbSet<TaxRate> TaxRates { get; set; }
Property Value
Methods
OnConfiguring(DbContextOptionsBuilder)
Override this method to configure the database (and other options) to be used for this context. This method is called for each instance of the context that is created. The base implementation does nothing.
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
Parameters
optionsBuilder
DbContextOptionsBuilderA builder used to create or modify options for this context. Databases (and other extensions) typically define extension methods on this object that allow you to configure the context.
Remarks
In situations where an instance of DbContextOptions may or may not have been passed to the constructor, you can use IsConfigured to determine if the options have already been set, and skip some or all of the logic in OnConfiguring(DbContextOptionsBuilder).
See DbContext lifetime, configuration, and initialization for more information and examples.
OnModelCreating(ModelBuilder)
Override this method to further configure the model that was discovered by convention from the entity types exposed in DbSet<TEntity> properties on your derived context. The resulting model may be cached and re-used for subsequent instances of your derived context.
protected override void OnModelCreating(ModelBuilder modelBuilder)
Parameters
modelBuilder
ModelBuilderThe builder being used to construct the model for this context. Databases (and other extensions) typically define extension methods on this object that allow you to configure aspects of the model that are specific to a given database.
Remarks
If a model is explicitly set on the options for this context (via UseModel(IModel)) then this method will not be run. However, it will still run when creating a compiled model.
See Modeling entity types and relationships for more information and examples.
SaveChanges()
Saves all changes made in this context to the database.
public override int SaveChanges()
Returns
- int
The number of state entries written to the database.
Remarks
This method will automatically call DetectChanges() to discover any changes to entity instances before saving to the underlying database. This can be disabled via AutoDetectChangesEnabled.
Entity Framework Core does not support multiple parallel operations being run on the same DbContext instance. This includes both parallel execution of async queries and any explicit concurrent use from multiple threads. Therefore, always await async calls immediately, or use separate DbContext instances for operations that execute in parallel. See Avoiding DbContext threading issues for more information and examples.
See Saving data in EF Core for more information and examples.
Exceptions
- DbUpdateException
An error is encountered while saving to the database.
- DbUpdateConcurrencyException
A concurrency violation is encountered while saving to the database. A concurrency violation occurs when an unexpected number of rows are affected during save. This is usually because the data in the database has been modified since it was loaded into memory.
SaveChangesAsync(CancellationToken)
Saves all changes made in this context to the database.
public override Task<int> SaveChangesAsync(CancellationToken cancellationToken = default)
Parameters
cancellationToken
CancellationTokenA CancellationToken to observe while waiting for the task to complete.
Returns
- Task<int>
A task that represents the asynchronous save operation. The task result contains the number of state entries written to the database.
Remarks
This method will automatically call DetectChanges() to discover any changes to entity instances before saving to the underlying database. This can be disabled via AutoDetectChangesEnabled.
Entity Framework Core does not support multiple parallel operations being run on the same DbContext instance. This includes both parallel execution of async queries and any explicit concurrent use from multiple threads. Therefore, always await async calls immediately, or use separate DbContext instances for operations that execute in parallel. See Avoiding DbContext threading issues for more information and examples.
See Saving data in EF Core for more information and examples.
Exceptions
- DbUpdateException
An error is encountered while saving to the database.
- DbUpdateConcurrencyException
A concurrency violation is encountered while saving to the database. A concurrency violation occurs when an unexpected number of rows are affected during save. This is usually because the data in the database has been modified since it was loaded into memory.
- OperationCanceledException
If the CancellationToken is canceled.