NHibernate没有调用SQL Server

时间:2016-08-19 19:34:51

标签: nhibernate nhibernate-mapping

调用此方法。

    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只是忽略了访问我的数据库视图的预期尝试?

2 个答案:

答案 0 :(得分:0)

我发现视图将属性“x”视为字符串。但是在nHibernate中我将它定义为Int64。这些类型差异很大程度上导致标准失败。但没有任何报告错误?

答案 1 :(得分:0)

仔细检查您的查询是否真的尝试使用您想要的确切类,并且映射也适用于完全相同的类。例如,要注意不同命名空间或程序集中具有相同名称的类。导致此类问题的一个原因是,如果您尝试查询实际上未在NHibernate中映射的类,那么NHibernate将返回空结果,而不是错误。

哦,你试过没有cache-element来排除这种情况吗?