唯一的工作,我身边已经找到下面使用功能NHibernate的代码片段所示。这很丑陋,因为它很难将SQL编码到映射中,但它确实有效。 Check属性设置为None,因此计数被忽略。我不知道您是否可以使用直线HBM文件来完成此操作,但可能有办法。如果在NHibernate(或Fluent NH)中有一个配置选项来设置预期的更新行数或在需要时忽略它,那将会很棒。
public class OrderMap : ClassMap<Order>
{
public OrderMap()
{
Id(c => c.Id, "order_id").GeneratedBy.Native();
Table("order");
Map(c => c.GroupId, "group_id");
Map(c => c.Status, "status");
Map(c => c.LocationNumber, "location");
SqlInsert("insert into order (group_id, status, location) values (?, ?, ?)").Check.None();
SqlUpdate("update order set group_id = ?, status = ?, location = ? where order_id = ?")).Check.None();
SqlDelete("delete order where order_id = ?").Check.None();
}
}
编辑: 对于那些不幸的人是不知道功能NHibernate的或爱痛苦的一代的手工HBM文件,这里是该样本映射HBM文件:
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-access="property" auto-import="true" default-cascade="none" default-lazy="true">
<class xmlns="urn:nhibernate-mapping-2.2" mutable="true" name="Your.DomainModel.Entities.Order, Your.DomainModel, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" table="order">
<id name="Id" type="System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" unsaved-value="0">
<column name="order_id" />
<generator class="identity" />
</id>
<property name="GroupId" type="System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="group_id" />
</property>
<property name="Status" type="System.Int16, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="status" />
</property>
<property name="LocationNumber" type="System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="loc_num" />
</property>
<sql-insert check="none">insert into order (group_id, status, location) values (?, ?, ?)</sql-insert>
<sql-update check="none">update order set group_id = ?, status = ?, location = ? where order_id = ?</sql-update>
<sql-delete check="none">delete order where order_id = ?</sql-delete>
</class>
</hibernate-mapping>
我不使用流利的NHibernate,你知道这适用于NHibernate设置?我不知道应该在哪里写(我不使用任何ClassMap,也不知道它是什么,而且我没有看到像SqlInsert之类的函数)。 – Carl
请参阅编辑我的答案。希望你没有手动创建HBM。但是,如果是,肯定看看Fluent NHibernate或NHibernate 3.0中新的流畅映射能力可以为你做什么。 –
谢谢你。是的,我正在手动创建HBM,但现在不是问题(我不觉得这特别困难)。 – Carl