为什么NHibernate没有返回任何数据?

时间:2013-10-20 11:06:08

标签: c# asp.net-mvc-4 nhibernate

我在配置NHibernate以检索MVC 4应用程序中的数据时遇到了一些问题。

为了简单起见,我已经在Index方法中配置了所有代码。

以下是我的类别控制器的代码:

Category Controller code

,这是我在web.config中的配置:

<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
    <session-factory name="NHibernate.Test">
      <property name="connection.driver_class">
        NHibernate.Driver.SqlClientDriver
      </property>
      <property name="connection.connection_string">
        Data Source=.;Initial Catalog=UsingNH;uid=myuid;Password=mypwd
      </property>
      <property name="adonet.batch_size">10</property>
      <property name="show_sql">true</property>
      <property name="dialect">NHibernate.Dialect.MsSql2005Dialect</property>
      <property name="use_outer_join">true</property>
      <property name="command_timeout">60</property>
      <property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>
      <property name="proxyfactory.factory_class">
        NHibernate.ByteCode.LinFu.ProxyFactoryFactory, NHibernate.ByteCode.LinFu
      </property>
    </session-factory>
  </hibernate-configuration>

类别的映射文件

<?xml version="1.0" encoding="utf-8" ?> 

<hibernate-mapping xmlns="nhibernate-mapping-2.2" namespace="UsingNHibernate.Models" assembly="UsingNHibernate">
  <class name="Category" table="Categories" lazy="false">

    <id name="Id" columnId="Id" unsaved-value="0">
      <generator class="native" />
    </id>

    <property name="Name">
      <column name="Name" data-type="varchar(50)" not-null="true" />
    </property>

  </class>
</hibernate-mapping>

和Category表架构是

CREATE TABLE [dbo].[Categories](
    [Id] [int] IDENTITY(1,1) NOT NULL,
    [Name] [varchar](50) NOT NULL,
 CONSTRAINT [PK_Category] PRIMARY KEY CLUSTERED 
(
    [Id] ASC
)
) ON [PRIMARY]

问题是该程序编译并运行良好但不返回任何类别。

代码

var lst = (List<Category>)criterion.List<Category>();

返回0项(在调试器中验证)。

我的配置或映射文件有问题吗?

评论是否需要其他信息。

感谢。

2 个答案:

答案 0 :(得分:14)

如果没有定义映射,那么如果查询实体列表,nhibernate将无声地失败并返回一个空列表。

我猜您不会将映射文件复制到bin目录。标记要复制的映射文件(通过属性)。

答案 1 :(得分:2)

我将Build Action映射文件的hbm属性更改为Embedded Resource, 然后我就可以获得数据了。

enter image description here

(它与OP的评论相同,但我将其发布为更易于注意的答案。)