1

我已经阅读了一些关于 fetch=join 的帖子 - http://nhforge.org/blogs/nhibernate/archive/2009/04/09/nhibernate-mapping-lt-many-to-one-gt.aspx (ser4ik.livejournal.aspx) com/2505.html) 所以我有一些问题,例如我有课

<class name="AttributesInf" table="attr_inf">      
 <id name="Id">
   <generator class="identity"/>
 </id>
 <property name="Name" />
    <property name="Desc"/>
</class> 

<class name="AttributeValue" table="attr_val">      
 <id name="Id">
   <generator class="identity"/>
 </id>
 <property name="Value" />
 <many-to-one name="AttrName" column="attrId"/>
</class> 

如果我在没有 set fetch="join" 的情况下使用这个映射,我会得到 sql:

Select av.Id, av.Value, av.attrId From attr_val av where av.Id=...()

然后单独的sql查询,如:

Select * From attr_inf where Id = av.attrId

所以我的结果是:

class AttrinuteInf 
{ 
int Id; 
string Name; 
string Desc; 
} 
class AttributeValue 
{ 
int Id; 
string  Value; 
AttributeInf AttrName;
}

如果我设置 fetch="join" 然后我得到一个查询:

Select u.Id, u.UserName, u.BlogId, b.Id, b.BlogName, b.BlogAuthor, b.BlogMsg 
from Users u
Left outer join Blogs b 
On u.BlogId=b.Id
Where u.Id = ...

所以我希望得到一堂课:

class AttributeValue
{
int Id;
string  Value;
string Name;
string Desc;
}

但是我的结果与我没有将 fetch 设置为“join”一样。

这可以吗?有没有办法<many-to-one>直接从类映射中获取属性?(不是 AttrName.Name,而只是 Name )

解释:

上面设置的部分映射没有显示我真正的问题。我想将一些实体映射为IDictionary<string,AttributeValue>. 我将其映射为

<map name="Attributes" table="attr_val" lazy="true" cascade="all-delete-orphan" inverse="true">
<key column="item_id"></key>
<index column="name"></index> //I don't have that item in class AttributeValue, that is why I try to get it from other table
<one-to-many class="AttributeValue"/>
</map>
4

3 回答 3

7

这不是在做你认为它在做的事情。使用 fetch=join 只是为了急切地加载关系的多方面。在这两种情况下,您最终都会返回相同的对象。默认情况下,NHibernate 将延迟加载相关实体(这就是您获得第二个查询的原因)。通过使用 fetch=join,您会立即请求整个对象关系,但它仍会像没有 fetch=join 那样填充对象。

于 2009-10-09T12:12:38.027 回答
1

这不是你描述的方式。您的实体不会根据您的要求而改变。

您将获得主要实体的实例列表,并获取与另一个实体的关联。因此,如果在您的代码中访问关联,您将找到值。

如果您不获取它,您将无法访问这些字段,因为它们不会从数据库中检索到。

于 2009-10-09T12:08:32.230 回答
1

我不明白你的问题。'fetch-join' 属性只定义了 NHibernate 生成的用于检索类实例的 sql 应该是什么样子。它与将返回的“什么”无关。NHibernate 会将记录集(即查询的结果)转换为正确的类实例。

如果您只想检索实体的某些部分(例如名称),则必须编写 HQL 查询,或使用 ICriteria API 并可能使用投影。

于 2009-10-09T12:09:21.450 回答