首页 > 代码库 > NHibernate的常见问题及解决方案

NHibernate的常见问题及解决方案

 

问题

异常:in expected: <end-of-text> (possibly an invalid or unmapped class name was used in the query) [from Customer]

解决方案:查看HQL语句查询的是否是实体类,映射文件属性是否正确:复制到输出目录à始终复制 。。生成操作à嵌入的资源。

问题2

异常:缺少必需的属性“name”。

解决方案:查看映射文件里,是否哪个<property>节点缺少name属性

问题3

      异常:“NHibernate.Proxy.CastleProxyFactory”的类型初始值设定项引发异常。

   解决方案:Nhibernate版本问题。。删除数据访问层与界面层对Nhibernate的引用,改为引用nhibernate2.0组件,改配置文件(App.config/web.config),到NHibernate-.GA-src/src/NhibernateText下面复制app.config.中Nhibernate的配置信息。

问题4

异常:Could not find the dialect in the configuration

   解决方案:配置文件错误。WEB项目应在web.config配置文件里配置Nhibernate。应用程序在App.config里配置Nhibernate.

问题5

      异常:could not resolve property: customerId of: CompanyModels.Customer [from CompanyModels.Customer c where c.customerId=:customerId]

解决方案:HQL语句里字段是代表实体类的属性,区分大小写。

 

问题6

    异常:不应有 <hibernate-mapping xmlns=‘urn:nhibernate-mapping-2.0‘>。

      解决方案:把2.0改为2.2即可,在CodeSmith中生成映射文件时为2.0,而Nhibernate2对应2.2

问题7

      异常:元素 命名空间“urn:nhibernate-mapping中的“bag”。 的子元素 命名空间“urn:nhibernate-mapping中的“many-to-many”。 无效。应为可能元素的列表: 命名空间“urn:nhibernate-mapping中的“loader, sql-insert, sql-update, sql-delete, sql-delete-all, filter”。。

       解决方案:多对多关系映射错误,看映射文件中<many-to-many>节点是否有多个,如果有请删除一个。只要引用对应的实体类即可。如:

<bag name="OrderProducts" table="OrderProduct" inverse="false" lazy="true" cascade="all-delete-orphan">

              <key>

                   <column name="`Order`" length="4" sql-type="int" not-null="true"/>

              </key>

      <many-to-many class="CompanyModels.Order, CompanyModels">

        <column name="Order" length="4" sql-type="int" not-null="true"/>

      </many-to-many>

              <many-to-many class="CompanyModels.Product, CompanyModels">

                   <column name="Product" length="4" sql-type="int" not-null="true"/>

              </many-to-many>

         </bag>

删除第一个<many-to-many>即可解决.