Nhibernate игнорирует несохраненные значения с помощью Guid (SQL Server CE) - PullRequest
1 голос
/ 10 ноября 2011

Это мое отображение:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="DomainModel" namespace="DomainModel">
  <class name="Cliente" table="Clientes">
    <id name="Id" column="ID" type="guid" unsaved-value="00000000-0000-0000-0000-000000000000">
      <generator class="guid.comb" />
    </id>
    <property name="Nombre" column="Nombre" not-null="true" type="string" length="50"  />
    <property name="Direccion" column="Direccion" not-null="false" type="string" length="75"  />
    <property name="Telefono" column="Telefono" not-null="false" type="string" length="15"  />
    <property name="Email" column="Email" not-null="false" type="string" length="50"  />
    <property name="FechaAlta" column="FAlta" not-null="true" type="DateTime"  />
    <list name="Pedidos" cascade="all-delete-orphan">
      <key column="Cliente"/>
      <index column="FechaEntrada"/>
      <one-to-many class="Pedido"/>
    </list>
  </class>
</hibernate-mapping>

Когда я пытаюсь вставить нового «Клиента» (Клиента) в базу данных, NHibernate генерирует вместо этого команду UPDATE, чтобы обновить клиента с идентификатором 00000000-0000-0000-0000-000000000000. Поскольку он не существует, я, естественно, получаю исключение:

InnerException: NHibernate.StaleStateException Сообщение = "Неожиданное количество строк: 0; ожидаемое: 1"

Я предполагаю, что это должна быть ошибка niber NHibernate, но я проверял свое сопоставление с другими сопоставлениями примеров guid в Интернете, и я не вижу своей ошибки.

Спасибо!

PS.- По запросу, это код, который я использую для вставки:

// METHOD 1
//BusinessTransaction bt = new BusinessTransaction(sesion);
//bt.Attach(cliente);
//bt.Commit();
//bt.Close();

// METHOD 2
ITransaction trans = sesion.BeginTransaction();
sesion.SaveOrUpdate(cliente);
trans.Commit();
sesion.Flush();

sesion - это объект ISession, созданный с помощью метода BuildSessionFactory конфигурации NHibernate. Метод 1 провоцирует описанную ошибку, ОБНОВЛЕНИЕ, когда он должен делать INSERT, тогда как Метод 2 работает, однако (я идиот и искал не тот файл базы данных) .

PPS.- Ради тестирования я изменил поля guid для автоматически увеличиваемых int идентификационных полей, но мои проблемы те же.

PPPS.- На всякий случай, это содержимое моего файла hibernate.cfg.xml:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
    <session-factory>
      <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
      <property name="dialect">NHibernate.Dialect.MsSqlCeDialect</property>
      <property name="connection.driver_class">NHibernate.Driver.SqlServerCeDriver</property>
      <property name="connection.connection_string">Data Source=Pedidos.sdf</property>
      <property name="show_sql">true</property>
      <property name="proxyfactory.factory_class">NHibernate.ByteCode.LinFu.ProxyFactoryFactory, NHibernate.ByteCode.LinFu</property>
      <mapping assembly="PedidosDomainModel" />
    </session-factory>
  </hibernate-configuration>

1 Ответ

1 голос
/ 12 апреля 2013

Вот одно из решений: сопоставьте идентификатор (вот как я отображаю его в Fluent, вы отсортируете эквивалент в сопоставлении XML)

Id(x => x.Id).GeneratedBy.Assigned();

И перед сохранением вы можете сделать что-то вроде этого:

if (client.HasEmptyId())
{
    client.Id = Guid.NewGuid();
    session.Save(client);
}
else
{
    session.Update(client);
}
...