Table of Contents

Class DatabaseDependencies

Namespace
Microsoft.EntityFrameworkCore.Storage
Assembly
Microsoft.EntityFrameworkCore.dll

Service dependencies parameter class for Database

This type is typically used by database providers (and other extensions). It is generally not used in application code.

public sealed record DatabaseDependencies : IEquatable<DatabaseDependencies>
Inheritance
DatabaseDependencies
Implements
Inherited Members

Remarks

Do not construct instances of this class directly from either provider or application code as the constructor signature may change as new dependencies are added. Instead, use this type in your constructor so that an instance will be created and injected automatically by the dependency injection container. To create an instance with some dependent services replaced, first resolve the object from the dependency injection container, then replace selected services using the C# 'with' operator. Do not call the constructor at any point in this process.

The service lifetime is Scoped. This means that each DbContext instance will use its own instance of this service. The implementation may depend on other services registered with any lifetime. The implementation does not need to be thread-safe.

Constructors

DatabaseDependencies(IQueryCompilationContextFactory, IUpdateAdapterFactory, IDiagnosticsLogger<Update>)

This is an internal API that supports the Entity Framework Core infrastructure and not subject to the same compatibility standards as public APIs. It may be changed or removed without notice in any release. You should only use it directly in your code with extreme caution and knowing that doing so can result in application failures when updating to a new Entity Framework Core release.

[EntityFrameworkInternal]
public DatabaseDependencies(IQueryCompilationContextFactory queryCompilationContextFactory, IUpdateAdapterFactory updateAdapterFactory, IDiagnosticsLogger<DbLoggerCategory.Update> logger)

Parameters

queryCompilationContextFactory IQueryCompilationContextFactory
updateAdapterFactory IUpdateAdapterFactory
logger IDiagnosticsLogger<DbLoggerCategory.Update>

Remarks

Do not call this constructor directly from either provider or application code as it may change as new dependencies are added. Instead, use this type in your constructor so that an instance will be created and injected automatically by the dependency injection container. To create an instance with some dependent services replaced, first resolve the object from the dependency injection container, then replace selected services using the C# 'with' operator. Do not call the constructor at any point in this process.

Properties

Logger

A logger for general update events.

public IDiagnosticsLogger<DbLoggerCategory.Update> Logger { get; }

Property Value

IDiagnosticsLogger<DbLoggerCategory.Update>

QueryCompilationContextFactory

Factory for compilation contexts to process LINQ queries.

public IQueryCompilationContextFactory QueryCompilationContextFactory { get; init; }

Property Value

IQueryCompilationContextFactory

UpdateAdapterFactory

Factory for creating update adapters.

public IUpdateAdapterFactory UpdateAdapterFactory { get; init; }

Property Value

IUpdateAdapterFactory

Methods

Equals(DatabaseDependencies?)

public bool Equals(DatabaseDependencies? other)

Parameters

other DatabaseDependencies

Returns

bool

Equals(object?)

public override bool Equals(object? obj)

Parameters

obj object

Returns

bool

GetHashCode()

public override int GetHashCode()

Returns

int

ToString()

public override string ToString()

Returns

string

<Clone>$()

public DatabaseDependencies <Clone>$()

Returns

DatabaseDependencies

Operators

operator ==(DatabaseDependencies?, DatabaseDependencies?)

public static bool operator ==(DatabaseDependencies? left, DatabaseDependencies? right)

Parameters

left DatabaseDependencies
right DatabaseDependencies

Returns

bool

operator !=(DatabaseDependencies?, DatabaseDependencies?)

public static bool operator !=(DatabaseDependencies? left, DatabaseDependencies? right)

Parameters

left DatabaseDependencies
right DatabaseDependencies

Returns

bool