Reo.Core.Database 10.0.28

There is a newer version of this package available.
See the version list below for details.
dotnet add package Reo.Core.Database --version 10.0.28
                    
NuGet\Install-Package Reo.Core.Database -Version 10.0.28
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Reo.Core.Database" Version="10.0.28" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Reo.Core.Database" Version="10.0.28" />
                    
Directory.Packages.props
<PackageReference Include="Reo.Core.Database" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Reo.Core.Database --version 10.0.28
                    
#r "nuget: Reo.Core.Database, 10.0.28"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Reo.Core.Database@10.0.28
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Reo.Core.Database&version=10.0.28
                    
Install as a Cake Addin
#tool nuget:?package=Reo.Core.Database&version=10.0.28
                    
Install as a Cake Tool

Reo.Core.Database

Описание пакета

Reo.Core.Database — это абстрактный слой для работы с базами данных, предназначенный для упрощения и унификации доступа к данным в приложениях на C#. Пакет предоставляет общий интерфейс для выполнения операций CRUD, поддерживает инструменты для аудита изменений, а также включает реализации для работы с MongoDB и PostgreSQL. Он решает проблему дублирования кода при работе с разными СУБД и обеспечивает централизованное управление конфигурацией и состоянием баз данных.

Основные компоненты

1. IDataProvider<TId>

Интерфейс для выполнения операций с базой данных (CRUD, фильтрация, агрегация). Предоставляет методы для работы с сущностями, включая вставку, обновление, удаление и выборку данных.

2. IDataProviderFactory

Фабрика для создания экземпляров IDataProvider<TId>. Используется для интеграции с контейнером зависимостей (DI) в ASP.NET Core и других фреймворках.

3. MongoDataProvider

Реализация IDataProvider<string> для работы с MongoDB. Поддерживает асинхронные операции, фильтрацию и инклюзию связанных данных (через Include).

4. PostgresClusterHealthCheck

Реализация проверки состояния кластера PostgreSQL. Использует Npgsql для проверки доступности узлов кластера и обеспечивает высокую отказоустойчивость.

5. UpdateDateInterceptor

Инструмент для автоматического обновления даты последнего изменения сущности. Может быть интегрирован в ORM-провайдеры для отслеживания изменений.

Требования

  • .NET версии: .NET Standard 2.0, .NET 6.0 и выше.
  • Зависимости:
    • Npgsql (для PostgreSQL-проверок состояния).
    • Microsoft.Extensions.DependencyInjection (для интеграции с DI-контейнером).

Установка

Используйте следующие команды для установки пакета:

Install-Package Reo.Core.Database

или

dotnet add package Reo.Core.Database

Настройка

Регистрация в ASP.NET Core

Добавьте сервисы в Startup.cs или Program.cs:

services.AddSingleton<IDataProviderFactory, DataProviderFactory>();
services.AddSingleton<IDataProvider<string>, MongoDataProvider>();

Конфигурационные параметры

  • Строка подключения MongoDB: Указывается в appsettings.json или через DI-контейнер.
  • Проверка состояния PostgreSQL: Настройте параметры подключения в HealthChecks через PostgresClusterHealthCheck.

Использование

Пример 1: CRUD-операции с MongoDB

public class UserService
{
    private readonly IDataProvider<string> _dataProvider;

    public UserService(IDataProvider<string> dataProvider)
    {
        _dataProvider = dataProvider;
    }

    public async Task<User> GetUserByIdAsync(string id)
    {
        return await _dataProvider.Query<User>(x => x.Id == id).FirstOrDefaultAsync();
    }

    public async Task CreateUserAsync(User user)
    {
        await _dataProvider.InsertAsync(user);
    }
}

Пример 2: Проверка состояния PostgreSQL-кластера

public class HealthCheckService
{
    private readonly IHealthCheck _healthCheck;

    public HealthCheckService(IHealthCheck healthCheck)
    {
        _healthCheck = healthCheck;
    }

    public async Task CheckClusterHealthAsync()
    {
        var result = await _healthCheck.CheckHealthAsync(new HealthCheckContext());
        if (result.Status != HealthStatus.Healthy)
        {
            // Обработка ошибки
        }
    }
}

Пример 3: Автоматическое обновление даты изменения

public class Product
{
    public string Id { get; set; }
    public string Name { get; set; }
    public DateTime LastUpdated { get; set; }
}

// В конфигурации ORM:
services.AddSingleton<UpdateDateInterceptor>();

Лицензия

Данный пакет распространяется под лицензией MIT.

Product Compatible and additional computed target framework versions.
.NET net10.0 is compatible.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on Reo.Core.Database:

Package Downloads
Reo.Core.Testing

Package Description

Reo.Core.IntegrationTesting

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
10.0.30 0 2/12/2026
10.0.29 0 2/12/2026
10.0.28 29 2/11/2026
10.0.27 39 2/11/2026
10.0.26 86 2/9/2026
10.0.25 82 2/9/2026
10.0.24 95 2/9/2026
10.0.23 88 2/9/2026
10.0.22 88 2/9/2026
10.0.21 94 2/9/2026
10.0.20 93 2/9/2026
10.0.15 109 2/6/2026
10.0.14 101 2/6/2026
10.0.13 112 2/4/2026
10.0.12 104 2/3/2026
10.0.11 127 2/2/2026
10.0.10 115 1/29/2026
10.0.9 113 1/29/2026
10.0.8 120 1/27/2026
10.0.6 112 1/26/2026
Loading failed