feat: Implementa gestione intelligente della chiave sorgente con rilevamento PK

- Aggiunge rilevamento automatico Primary Key per connessioni database
- Rimuove completamente il fallback automatico per lato sorgente
- Implementa selezione manuale obbligatoria per file e sorgenti non-DB
- Migliora UI con suggerimenti intelligenti e feedback visivo
- Aggiunge validazione multi-livello (UI, pre-transfer, runtime)
- Introduce metodo GetPrimaryKeyFieldAsync in IDatabaseManager
- Modifica GenerateSourceKey per richiedere sempre campo specifico
- Implementa controllo IsTransferButtonEnabled per validazione form

Breaking changes:
- La generazione automatica delle chiavi sorgente è stata rimossa
- Il campo chiave sorgente è ora obbligatorio quando si usa il sistema associazioni

Fixes: Risolve problema di discovery schema vuoto con selezione database
This commit is contained in:
2025-06-28 02:05:59 +02:00
parent 207d6fc845
commit 51c61eabf7
29 changed files with 2748 additions and 104 deletions
@@ -45,6 +45,16 @@ public interface IDatabaseManager : IDisposable
/// 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>
@@ -54,6 +64,11 @@ public interface IDatabaseManager : IDisposable
/// 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>
@@ -61,11 +76,11 @@ public interface IDatabaseManager : IDisposable
/// </summary>
public class DbColumnInfo
{
public string Name { get; set; }
public string DataType { get; set; }
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; }
public string? ReferencedTable { get; set; }
public string? ReferencedColumn { get; set; }
}