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:
@@ -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; }
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user