5

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

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

这是我的类别控制器的代码:

类别控制器代码

这是我在 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>

并且类别表架构是

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 个项目(在调试器中验证)。

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

如果需要其他信息,请发表评论。

谢谢。

4

2 回答 2

16

如果没有定义映射,nhibernate 将简单地失败并在您查询实体列表时返回一个空列表。

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

于 2013-10-20T11:22:37.823 回答
3

我将映射文件的Build Action属性更改为,然后我可以获取数据。hbmEmbedded Resource

在此处输入图像描述

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

于 2017-05-26T09:41:32.360 回答