2238ddc4bf
- Rimossi messaggi di successo per validazione query per ridurre ingombro visivo - Eliminati alert informativi delle colonne rilevate dalla query - Rimossa notificazione "Query validata!" nella sezione mapping - Mantenuti solo i messaggi di errore quando necessario - Migliorata UX con interfaccia più pulita e focalizzata sull'essenziale - Funzionalità di estrazione colonne e mapping completamente preservata
92 lines
3.2 KiB
C#
92 lines
3.2 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq.Expressions;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace DataConnection.Interfaces;
|
|
|
|
/// <summary>
|
|
/// Interfaccia per la gestione di database preesistenti tramite EF Core
|
|
/// </summary>
|
|
public interface IDatabaseManager : IDisposable
|
|
{
|
|
/// <summary>
|
|
/// Verifica la connessione al database
|
|
/// </summary>
|
|
Task<bool> TestConnectionAsync();
|
|
|
|
/// <summary>
|
|
/// Ottiene entità dal database in base ai criteri specificati
|
|
/// </summary>
|
|
/// <typeparam name="T">Tipo di entità</typeparam>
|
|
/// <param name="filter">Espressione di filtro</param>
|
|
/// <param name="orderBy">Espressione di ordinamento</param>
|
|
/// <param name="includeProperties">Proprietà di navigazione da includere</param>
|
|
/// <param name="skip">Numero di elementi da saltare</param>
|
|
/// <param name="take">Numero di elementi da prendere</param>
|
|
Task<IEnumerable<T>> GetAsync<T>(
|
|
Expression<Func<T, bool>>? filter = null,
|
|
Func<IQueryable<T>, IOrderedQueryable<T>>? orderBy = null,
|
|
string includeProperties = "",
|
|
int? skip = null,
|
|
int? take = null) where T : class;
|
|
|
|
/// <summary>
|
|
/// Ottiene un'entità singola in base alla chiave primaria
|
|
/// </summary>
|
|
Task<T?> GetByIdAsync<T>(object id) where T : class;
|
|
|
|
/// <summary>
|
|
/// Esegue una query SQL raw
|
|
/// </summary>
|
|
Task<IEnumerable<T>> ExecuteQueryAsync<T>(string sql, params object[] parameters) where T : class;
|
|
|
|
/// <summary>
|
|
/// Esegue una query SQL raw e restituisce i risultati come dictionary
|
|
/// </summary>
|
|
Task<List<Dictionary<string, object>>> ExecuteRawQueryAsync(string sql, params object[] parameters);
|
|
|
|
/// <summary>
|
|
/// Esegue un comando SQL che non restituisce risultati
|
|
/// </summary>
|
|
Task<int> ExecuteCommandAsync(string sql, params object[] parameters);
|
|
|
|
/// <summary>
|
|
/// Ottiene l'elenco dei database disponibili sul server
|
|
/// </summary>
|
|
Task<List<string>> GetAvailableDatabasesAsync();
|
|
|
|
/// <summary>
|
|
/// Cambia il database corrente per la connessione
|
|
/// </summary>
|
|
Task ChangeDatabaseAsync(string databaseName);
|
|
/// <summary>
|
|
/// Ottiene i metadati delle tabelle nel database
|
|
/// </summary>
|
|
Task<IDictionary<string, IEnumerable<DbColumnInfo>>> GetDatabaseSchemaAsync();
|
|
|
|
/// <summary>
|
|
/// Ottiene tutti i record da una tabella specifica come dizionari chiave-valore
|
|
/// </summary>
|
|
Task<IEnumerable<Dictionary<string, object>>> GetAllRecordsAsync(string tableName);
|
|
|
|
/// <summary>
|
|
/// Ottiene il nome del campo Primary Key di una tabella specifica
|
|
/// </summary>
|
|
Task<string?> GetPrimaryKeyFieldAsync(string tableName);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Informazioni su una colonna del database
|
|
/// </summary>
|
|
public class DbColumnInfo
|
|
{
|
|
public string Name { get; set; } = string.Empty;
|
|
public string DataType { get; set; } = string.Empty;
|
|
public bool IsNullable { get; set; }
|
|
public bool IsPrimaryKey { get; set; }
|
|
public bool IsForeignKey { get; set; }
|
|
public string? ReferencedTable { get; set; }
|
|
public string? ReferencedColumn { get; set; }
|
|
}
|