Come posso mappare un dizionario utilizzando Fluent NHibernate automapping?
-
20-09-2019 - |
Domanda
Ho un'entità in questo modo:
public class Land
{
public virtual IDictionary<string, int> Damages { get; set; }
// and other properties
}
Ogni volta che cerco di usare automapping con il seguente codice:
var sessionFactory = Fluently.Configure()
.Database(SQLiteConfiguration.Standard.InMemory)
.Mappings(m => m.AutoMappings.Add(AutoMap.AssemblyOf<Land>))
.BuildSessionFactory();
ottengo il seguente errore:
{"The type or method has 2 generic parameter(s), but 1 generic argument(s) were
provided. A generic argument must be provided for each generic parameter."}
Qualcuno può dirmi che cosa sto facendo male? Inoltre, questo è solo un semplice esempio. Ho molto più dizionari che solo questo.
Soluzione
E 'impossibile con NHibernate.
Altri suggerimenti
Trovato alcune tracce che questo non è possibile . Alcune tracce, che è recentemente implementato .
ancora indagando. :)
Questo sembra abbastanza promettente (non prova ancora).
Quindi, nel tuo caso dovrebbe assomigliare =>
public class LandMap : ClassMap<Land>
{
public LandMap()
{
(...)
HasMany(x => x.Damages)
.WithTableName("Damages")
.KeyColumnNames.Add("LandId")
.Cascade.All()
.AsMap<string>(
index => index.WithColumn("DamageType").WithType<string>(),
element => element.WithColumn("Amount").WithType<int>()
);
}
}
Tenete a mente - è dovrebbe . Non ho prove di esso.
Una possibile soluzione che dovrebbe in teoria il lavoro con automapping:
public class DamagesDictionary : Dictionary<string, int>
{
}
Land.cs
public class Land
{
public virtual DamagesDictionary Damages { get; set; }
// and other properties
}
o un approccio più generico ...
public class StringKeyedDictionary<T> : Dictionary<string, T>
{
}
Land.cs
public class Land
{
public virtual StringKeyedDictionary<int> Damages { get; set; }
// and other properties
}