Reo.Core.Database
10.0.29
See the version list below for details.
dotnet add package Reo.Core.Database --version 10.0.29
NuGet\Install-Package Reo.Core.Database -Version 10.0.29
<PackageReference Include="Reo.Core.Database" Version="10.0.29" />
<PackageVersion Include="Reo.Core.Database" Version="10.0.29" />
<PackageReference Include="Reo.Core.Database" />
paket add Reo.Core.Database --version 10.0.29
#r "nuget: Reo.Core.Database, 10.0.29"
#:package Reo.Core.Database@10.0.29
#addin nuget:?package=Reo.Core.Database&version=10.0.29
#tool nuget:?package=Reo.Core.Database&version=10.0.29
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 | Versions 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. |
-
net10.0
- AspNetCore.HealthChecks.NpgSql (>= 9.0.0)
- AspNetCore.HealthChecks.Redis (>= 9.0.0)
- AspNetCore.HealthChecks.UI.Client (>= 9.0.0)
- FluentValidation (>= 12.1.1)
- FluentValidation.AspNetCore (>= 11.3.1)
- Flurl (>= 4.0.0)
- Flurl.Http (>= 4.0.2)
- Flurl.Http.Newtonsoft (>= 0.9.1)
- Humanizer.Core (>= 3.0.1)
- IdentityModel (>= 7.0.0)
- JetBrains.Annotations (>= 2025.2.4)
- LinqKit.Core (>= 1.2.9)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 10.0.2)
- Microsoft.AspNetCore.Authentication.OpenIdConnect (>= 10.0.2)
- Microsoft.AspNetCore.Mvc.NewtonsoftJson (>= 10.0.2)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.2)
- Microsoft.CodeAnalysis.Analyzers (>= 3.11.0)
- Microsoft.CodeAnalysis.Common (>= 5.0.0)
- Microsoft.CodeAnalysis.CSharp (>= 5.0.0)
- Microsoft.CodeAnalysis.CSharp.Workspaces (>= 5.0.0)
- Microsoft.CodeAnalysis.Workspaces.Common (>= 5.0.0)
- Microsoft.CodeAnalysis.Workspaces.MSBuild (>= 5.0.0)
- Microsoft.EntityFrameworkCore (>= 10.0.2)
- Microsoft.EntityFrameworkCore.Design (>= 10.0.2)
- Microsoft.EntityFrameworkCore.Relational (>= 10.0.2)
- Microsoft.Extensions.Caching.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Caching.Memory (>= 10.0.2)
- Microsoft.Extensions.Caching.StackExchangeRedis (>= 10.0.2)
- Microsoft.Extensions.Configuration (>= 10.0.2)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Configuration.Binder (>= 10.0.2)
- Microsoft.Extensions.DependencyInjection (>= 10.0.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Diagnostics.HealthChecks.EntityFrameworkCore (>= 10.0.2)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Http.Polly (>= 10.0.2)
- Microsoft.Extensions.Logging (>= 10.0.2)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Options (>= 10.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.2)
- NEST (>= 7.17.5)
- Newtonsoft.Json (>= 13.0.4)
- Npgsql.EntityFrameworkCore.PostgreSQL (>= 10.0.0)
- Polly (>= 8.5.0)
- RedLock.net (>= 2.3.2)
- Reo.Core.Database.Abstractions (>= 10.0.29)
- Reo.Core.DataModels (>= 10.0.29)
- Reo.Core.DistributedCache (>= 10.0.29)
- Reo.Core.HealthCheck (>= 10.0.29)
- Reo.Core.Hosting (>= 10.0.29)
- Reo.Core.IdentityModel (>= 10.0.29)
- Reo.Core.PredicateBuilder (>= 10.0.29)
- stbychkov.AutoLoggerMessage (>= 1.0.15)
- Swashbuckle.AspNetCore (>= 10.1.2)
- System.ComponentModel.Annotations (>= 5.0.0)
- System.IO.Abstractions (>= 22.1.0)
- System.Linq.Async (>= 7.0.0)
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.32 | 0 | 2/13/2026 |
| 10.0.31 | 0 | 2/13/2026 |
| 10.0.30 | 29 | 2/12/2026 |
| 10.0.29 | 28 | 2/12/2026 |
| 10.0.28 | 37 | 2/11/2026 |
| 10.0.27 | 46 | 2/11/2026 |
| 10.0.26 | 91 | 2/9/2026 |
| 10.0.25 | 88 | 2/9/2026 |
| 10.0.24 | 99 | 2/9/2026 |
| 10.0.23 | 92 | 2/9/2026 |
| 10.0.22 | 95 | 2/9/2026 |
| 10.0.21 | 103 | 2/9/2026 |
| 10.0.20 | 97 | 2/9/2026 |
| 10.0.15 | 114 | 2/6/2026 |
| 10.0.14 | 105 | 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 |