这是我的映射:
<?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>
当我尝试将新的“Cliente”(客户)插入数据库时,NHibernate生成一个UPDATE命令,希望用ID 00000000-0000-0000-0000-000000000000更新客户。因为它不存在,我自然得到例外:
InnerException:NHibernate.StaleStateException Message =“意外的行数:0;预期:1”
我猜这必须是一个noob 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 是使用NHibernate Configuration的BuildSessionFactory方法创建的ISession对象。 方法1 引发所描述的错误,当它应该执行INSERT时更新,而方法2 工作,但是(我是个白痴,看起来是错误的数据库)文件)。
PPS.-为了测试我已经更改了自动递增的int标识字段的guid字段,但我的问题是相同的。
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>
答案 0 :(得分:1)
这是一个解决方案:映射Id(我在Fluent中映射它的方式,你将在XML映射中找出一个等价物)
Id(x => x.Id).GeneratedBy.Assigned();
在保存之前,您可以执行以下操作:
if (client.HasEmptyId())
{
client.Id = Guid.NewGuid();
session.Save(client);
}
else
{
session.Update(client);
}