Nhibernate Mapping Self Rejend Table?
-
29-10-2019 - |
Question
C'est peut-être très simple, mais je pense que je manque quelque chose. J'ai une table auto-jointe Units
, chaque unité a une unité principale:
Afin que je puisse interroger pour quelque chose comme ça:
La table units
est mappé à la classe suivante:
public class Units
{
public virtual int Unit_Id { get; private set; }
public virtual string Unit { get; set; }
public virtual decimal Unit_Value { get; set; }
public virtual Units Main_Unit { get; set; }
}
Avec le fichier de mappage .hbm comme suit:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="NewA.Domain" namespace="NewA.Domain">
<class name="NewA.Domain.Entities.Units,NewA.Domain" table="Units">
<id name="Unit_Id" column="Unit_Id" type="Int32" length="4" unsaved-value="0">
<generator class="native">
</generator>
</id>
<property name="Unit" column="Unit" type="string" length="50" not-null="true"/>
<one-to-one name="Main_Unit" class="NewA.Domain.Entities.Units,NewA.Domain"/>
</class>
</hibernate-mapping>
Lors du test de ces entités avec le code suivant:
Units unit = _UnitsRepository.GetById(2);
string parent_unitname = unit.Main_Unit.Unit;
Assert.AreEqual("pack",parent_unitname);
J'ai eu l'exppetion suivante:
Expected values to be equal. Expected Value : "pack" Actual Value : "kg"
Le problème est que le Main_Unit
propriété du Unit
L'entité se fait référence, alors ce qui me manque ici?
La solution
Vous avez besoin de mappage de plusieurs à un plutôt un à un. Essayez cette configuration:
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class xmlns="urn:nhibernate-mapping-2.2" name="NewA.Domain.Entities.Units.Units, NewA.Domain, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" table="`Units`">
<id name="Unit_Id" type="System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="Unit_Id" />
<generator class="native" />
</id>
<property name="Unit" type="System.String, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="Unit" />
</property>
<property name="Unit_Value" type="System.Decimal, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="Unit_Value" />
</property>
<many-to-one class="NewA.Domain.Entities.Units.Units, NewA.Domain, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" name="Main_Unit">
<column name="Main_Unit_id" />
</many-to-one>
</class>
</hibernate-mapping>
Je vous suggère d'essayer Nhibernate courant - Il peut générer dynamiquement des mappages pour vous. Voici la configuration que j'ai utilisée:
var fluent = Fluently.Configure()
.Mappings(c => c.AutoMappings.Add(AutoMap.AssemblyOf<Units>()
.Override<Units>(u => u.Id(uu => uu.Unit_Id).GeneratedBy.Native())))
.Database(() => SQLiteConfiguration.Standard.UsingFile("test.sqlite3"));
var configuration = fluent.BuildConfiguration();
// Generate database schema
new SchemaExport(configuration).Create(false, true);
var sessionFactory = configuration.BuildSessionFactory();
// Now just open session and do whatever you need
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow