Отказ от ответственности, этот ответ больше связан с содержанием, обсуждаемым здесь https://stackoverflow.com/a/29730411/1679310 (Комментарии)
Позвольте мне предоставить вам более подробную информацию, связанную с вашим отображением.
Во-первых, уменьшите полные имена:
// here we have namespace, not needed below for classes, if is the same
<hibernate-mapping ... namespace="NhibernateTesting.Models" >
Исходное сопоставление классов прокомментировано, мой подход заменяет его:
// <class name="NhibernateTesting.Models.ProductList" table="ProductList" lazy="false">
<class name="ProductList" table="ProductList"
lazy="true" // always use LAZY
batch-size="25" // optimization for loading - avoid 1 + N
>
//<id name="Id">
// <generator class="native" />
//</id>
// more readable version
<id name="Id" generator="native" />
// these are OK
<property name="Name" />
<property name="Owner" />
// collection should be ALWAYS lazy
// <bag name="Viewers" table="ProductListViewer" lazy="false">
// and also, optimization as batch size is needed
<bag name="Viewers" table="ProductListViewer"
lazy="true" // LAZY is must,
batch-size="25" cool optimization to avoid 1 + N
>
<key column="ProductListId" />
<element column="Username" type="System.String"/>
</bag>
// I would never use MANY-TO-MANY
// <bag name="Products" table="ProductListProductXRef" lazy="false" cascade="all" fetch="select">
<bag name="Products" table="ProductListProductXRef"
inverse="true" // in many to many only one side could be inverse
lazy="true"
cascade="none" // cascade here means, delete PRODUCTS
// not the pairing table, so I would expect that we need none
fetch="select">
<key column="ProductListId" />
// I would avoid many to many if possible
<many-to-many column="ProductId" class="NhibernateTesting.Models.Product" />
...
Проверьте эти ссылки для более подробной информации.
Лень
Пакетная загрузка
Избегайте многих ко многим
Когда использовать каскадирование
Это будут мои предложения, которые применимы ко всем сопоставлениям.
В общем, это должно быть сопоставление классов
<class
name="ProductList"
table="ProductList"
lazy="true"
batch-size="25"
>
В случае, если нам нужно управление версиями:
<class
name="ProductList"
table="ProductList"
lazy="true"
batch-size="25"
optimistic-lock="version"
dynamic-update="true"
>
<version name="Timestamp" generated="always" unsaved-value="null" type="BinaryBlob">
<column name="RowVersion" not-null="false" sql-type="timestamp"/>
</version>
Это должно быть сопоставление коллекции:
<bag name="Items"
lazy="true"
inverse="true"
batch-size="25"
cascade="all-delete-orphan">
<key column="Item_ID" />
<one-to-many class="SomeItemClass"/>
</bag>
person
Radim Köhler
schedule
21.04.2015