Table of Contents

Class ModelDependencies

Namespace
Microsoft.EntityFrameworkCore.Infrastructure
Assembly
Microsoft.EntityFrameworkCore.dll

Service dependencies parameter class for IModel

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

public sealed record ModelDependencies : IEquatable<ModelDependencies>
Inheritance
ModelDependencies
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

ModelDependencies(IDiagnosticsLogger<Model>)

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 ModelDependencies(IDiagnosticsLogger<DbLoggerCategory.Model> logger)

Parameters

logger IDiagnosticsLogger<DbLoggerCategory.Model>

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

Gets the logger.

public IDiagnosticsLogger<DbLoggerCategory.Model> Logger { get; init; }

Property Value

IDiagnosticsLogger<DbLoggerCategory.Model>

Methods

Equals(ModelDependencies?)

public bool Equals(ModelDependencies? other)

Parameters

other ModelDependencies

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

Returns

ModelDependencies

Operators

operator ==(ModelDependencies?, ModelDependencies?)

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

Parameters

left ModelDependencies
right ModelDependencies

Returns

bool

operator !=(ModelDependencies?, ModelDependencies?)

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

Parameters

left ModelDependencies
right ModelDependencies

Returns

bool