NHibernate - как сопоставить словарь? - PullRequest
2 голосов
/ 13 ноября 2011

Я пытаюсь выяснить, как настроить отображение nhibernate для спецификации класса, показанной в примере кода ниже.часть, с которой у меня возникают проблемы, - это как сопоставить свойство BOM.Components, чтобы сопоставление было эквивалентно SQL, который я опубликовал ниже.

Вот мое отображение для спецификации пока::

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="Inventory.Core"
                   namespace="Inventory.Core.Entities">
  <class name="BOM" table="bom">
    <id name="Id" column="bom_id">
      <generator class="hilo" />
    </id>
    <many-to-one name="Product" class="Material" column="mtrl_id" foreign-key="fk_BOM_Material" unique="true" not-null="true" />    
    <map name="Components" table="bom_cmpnnts">
       <key column="bom_id" foreign-key="fk_BOMComponent_BOM" not-null="true" />
   </map>
  </class>
</hibernate-mapping>

Обновление:

Вот отображение для BOMComponent:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="Inventory.Core"
                   namespace="Inventory.Core.Entities">
  <class name="BOMComponent" table="bom_cmpnnt">
    <id name="Id" column="bom_cmpnnt_id">
      <generator class="hilo" />
    </id>
    <version name="Version" column="bom_cmpnnt_vrsn" />
    <many-to-one name="Component"  class="Material" column="mtrl_id" foreign-key="fk_BOMComponent_Material" not-null="true" />
    <property name="Unit" column="bom_cmpnnt_unt" not-null="true" />
    <property name="Quantity" column="bom_cmpnnt_qntty" not-null="true" />
    <many-to-one name="User"  class="User" column="upsrt_usr_id" foreign-key="fk_BOMComponent_User" lazy="false" not-null="true" />
    <property name="Timestamp" column="upsrt_dttm" generated="always" />
  </class>
</hibernate-mapping>

Классы:

public class BOM
{
    int Id { get; set; }
    Material Product { get; set; }
    IDictionary<int, BOMComponent> Components { get; set; } 
    //    Key = BOMComponent.Material.Id
    //    for each BOM, materials should be unique

    //other properties ...
}
public class BOMComponent
{
    int Id { get; set; }
    Material Material { get; set; }

    //other properties ...
}
public class Material
{
    int Id { get; set; }

    //other properties
}

Вот как должен выглядеть SQL:

delimiter $$

CREATE TABLE `mtrl` (
  `mtrl_id` int(11) NOT NULL,
  PRIMARY KEY (`mtrl_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8$$

delimiter $$

CREATE TABLE `bom` (
  `bom_id` int(11) NOT NULL,
  `mtrl_id` int(11) NOT NULL,
  PRIMARY KEY (`bom_id`),
  UNIQUE KEY `mtrl_id_UNIQUE` (`mtrl_id`),
  KEY `fk_BOM_Material` (`mtrl_id`),
  CONSTRAINT `fk_BOM_Material` FOREIGN KEY (`mtrl_id`) REFERENCES `mtrl` (`mtrl_id`) ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8$$

delimiter $$

CREATE TABLE `bom_cmpnnt` (
  `bom_cmpnnt_id` int(11) NOT NULL,
  `bom_id` int(11) NOT NULL,
  `mtrl_id` int(11) NOT NULL,
  PRIMARY KEY (`bom_cmpnnt_id`),
  UNIQUE KEY `IX_BOMComponent_UQ` (`bom_id`,`mtrl_id`),
  KEY `fk_BOMComponent_BOM` (`bom_id`),
  KEY `fk_BOMComponent_Material` (`mtrl_id`),
  CONSTRAINT `fk_BOMComponent_BOM` FOREIGN KEY (`bom_id`) REFERENCES `bom` (`bom_id`) ON DELETE CASCADE ON UPDATE NO ACTION,
  CONSTRAINT `fk_BOMComponent_Material` FOREIGN KEY (`mtrl_id`) REFERENCES `mtrl` (`mtrl_id`) ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8$$

1 Ответ

1 голос
/ 13 ноября 2011

Я не хочу отвечать на свой вопрос, но я получил его так, как я хотел, используя эти два сопоставления:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="Inventory.Core"
                   namespace="Inventory.Core.Entities">
  <class name="BOM" table="bom">
    <id name="Id" column="bom_id">
      <generator class="hilo" />
    </id>
    <version name="Version" column="bom_vrsn" />
    <many-to-one name="Product" class="Material" column="mtrl_id" foreign-key="fk_BOM_Material" unique="true" not-null="true" />

    <map name="Components" table="bom_cmpnnt">
      <key column="bom_id" foreign-key="fk_BOMComponent_BOM" not-null="true" />
      <index column="mtrl_id" type="System.Int32" /> 
      <composite-element class="BOMComponent" />
    </map>
    <many-to-one name="User"  class="User" column="upsrt_usr_id" foreign-key="fk_BOM_User" lazy="false" not-null="true" />
    <property name="Timestamp" column="upsrt_dttm" generated="always" />
  </class>
</hibernate-mapping>

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="Inventory.Core"
                   namespace="Inventory.Core.Entities">
  <class name="BOMComponent" table="bom_cmpnnt">
    <id name="Id" column="bom_cmpnnt_id">
      <generator class="hilo" />
    </id>
    <version name="Version" column="bom_cmpnnt_vrsn" />
    <many-to-one name="Component"  class="Material" column="mtrl_id" foreign-key="fk_BOMComponent_Material" not-null="true" />
    <property name="Unit" column="bom_cmpnnt_unt" not-null="true" />
    <property name="Quantity" column="bom_cmpnnt_qntty" not-null="true" />
    <many-to-one name="User"  class="User" column="upsrt_usr_id" foreign-key="fk_BOMComponent_User" lazy="false" not-null="true" />
    <property name="Timestamp" column="upsrt_dttm" generated="always" />
  </class>
</hibernate-mapping>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...