调用此方法。
public IList<MyStuff> GetMyStuff(Int64 MyStuffId)
{
ICriteria criteria = NHibernateSessionManager.Instance.GetSession().CreateCriteria(typeof(MyStuff));
criteria.Add(Expression.Eq("x", MyStuff));
return criteria.List<MyStuff>();
}
但如果我描述SQL Server,我可以看到NHibernate没有尝试访问服务器。
不会抛出任何错误。只是criteria.List()
只返回0行。
MyStuff
是一个类
public class MyStuff {
public virtual int Id { get; set; }
public virtual int x { get; set; }
... more attributes ....
public override int GetHashCode() {
return (GetType().FullName + "|" + Id.ToString()).GetHashCode();
}
}
MyStuff是一个HBM映射:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" auto-import="false" assembly="MyStuff" namespace="My.Stuff" default-lazy="false">
<class name ="MyStuff" table="dbo.viewMyStuff" dynamic-update="false" lazy="false">
<cache usage="read-only"/>
<id name="Id" column="Id" type="int">
<generator class="native" />
</id>
<property name="x" />
.... other properties
</class>
</hibernate-mapping>
以下作品只是:
select * from viewMyStuff
NHibernate与同一项目中的其他类/视图完全一样。
事实上,如果我故意错误地打扰&#34;表&#34;在HBM文件中&#34; XviewXMyStuffX&#34; NHibernate对输入错误没有任何问题。为什么NHibernate只是忽略了访问我的数据库视图的预期尝试?
答案 0 :(得分:0)
我发现视图将属性“x”视为字符串。但是在nHibernate中我将它定义为Int64。这些类型差异很大程度上导致标准失败。但没有任何报告错误?
答案 1 :(得分:0)
仔细检查您的查询是否真的尝试使用您想要的确切类,并且映射也适用于完全相同的类。例如,要注意不同命名空间或程序集中具有相同名称的类。导致此类问题的一个原因是,如果您尝试查询实际上未在NHibernate中映射的类,那么NHibernate将返回空结果,而不是错误。
哦,你试过没有cache-element来排除这种情况吗?