Table of Contents

Class RelationalConnectionDependencies

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

Service dependencies parameter class for RelationalConnection

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

public sealed record RelationalConnectionDependencies : IEquatable<RelationalConnectionDependencies>
Inheritance
RelationalConnectionDependencies
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 'With...' methods. Do not call the constructor at any point in this process.

The service lifetime is Scoped. This means that each Microsoft.EntityFrameworkCore.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

RelationalConnectionDependencies(IDbContextOptions, IDiagnosticsLogger<Transaction>, IRelationalConnectionDiagnosticsLogger, INamedConnectionStringResolver, IRelationalTransactionFactory, ICurrentDbContext, IRelationalCommandBuilderFactory)

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.

public RelationalConnectionDependencies(IDbContextOptions contextOptions, IDiagnosticsLogger<DbLoggerCategory.Database.Transaction> transactionLogger, IRelationalConnectionDiagnosticsLogger connectionLogger, INamedConnectionStringResolver connectionStringResolver, IRelationalTransactionFactory relationalTransactionFactory, ICurrentDbContext currentContext, IRelationalCommandBuilderFactory relationalCommandBuilderFactory)

Parameters

contextOptions IDbContextOptions
transactionLogger IDiagnosticsLogger<Transaction>
connectionLogger IRelationalConnectionDiagnosticsLogger
connectionStringResolver INamedConnectionStringResolver
relationalTransactionFactory IRelationalTransactionFactory
currentContext ICurrentDbContext
relationalCommandBuilderFactory IRelationalCommandBuilderFactory

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 'With...' methods. Do not call the constructor at any point in this process.

Properties

ConnectionLogger

The logger to which connection messages will be written.

public IRelationalConnectionDiagnosticsLogger ConnectionLogger { get; init; }

Property Value

IRelationalConnectionDiagnosticsLogger

ConnectionStringResolver

A service for resolving a connection string from a name.

public INamedConnectionStringResolver ConnectionStringResolver { get; init; }

Property Value

INamedConnectionStringResolver

ContextOptions

The options for the current context instance.

public IDbContextOptions ContextOptions { get; init; }

Property Value

IDbContextOptions

CurrentContext

Contains the Microsoft.EntityFrameworkCore.DbContext instance currently in use.

public ICurrentDbContext CurrentContext { get; init; }

Property Value

ICurrentDbContext

RelationalCommandBuilderFactory

Contains the Microsoft.EntityFrameworkCore.DbContext instance currently in use.

public IRelationalCommandBuilderFactory RelationalCommandBuilderFactory { get; init; }

Property Value

IRelationalCommandBuilderFactory

RelationalTransactionFactory

A service for creating RelationalTransaction instances.

public IRelationalTransactionFactory RelationalTransactionFactory { get; init; }

Property Value

IRelationalTransactionFactory

TransactionLogger

The logger to which transaction messages will be written.

public IDiagnosticsLogger<DbLoggerCategory.Database.Transaction> TransactionLogger { get; init; }

Property Value

IDiagnosticsLogger<Transaction>

Methods

Equals(RelationalConnectionDependencies?)

public bool Equals(RelationalConnectionDependencies? other)

Parameters

other RelationalConnectionDependencies

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 RelationalConnectionDependencies <Clone>$()

Returns

RelationalConnectionDependencies

Operators

operator ==(RelationalConnectionDependencies?, RelationalConnectionDependencies?)

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

Parameters

left RelationalConnectionDependencies
right RelationalConnectionDependencies

Returns

bool

operator !=(RelationalConnectionDependencies?, RelationalConnectionDependencies?)

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

Parameters

left RelationalConnectionDependencies
right RelationalConnectionDependencies

Returns

bool