我如何解决NHibernate.MappingException

时间:2013-01-23 20:56:48

标签: c# sql nhibernate nhibernate-mapping

enter image description here 我有一个数据库,hbm映射文件和位于类库中的App.config。现在从一个测试项目我引用该库并尝试调用我创建的HibernateHelper类,在运行时抛出以下错误:

NHibernate.MappingException:无法编译映射文档:HibernateExample.Mappings.Products.hbm.xml

请记住,这是一个从Test项目引用的类库。 如果我将其输出类型更改为控制台应用程序,它运行正常。但是,当我将其更改回类库并从我的测试项目中引用它时,它会引发上面提到的错误。

我尝试添加config.Configure()但会抛出NhibernateDuplicateMapping异常。

FIXED: 通过从appconfig中删除修复了重复映射问题。并通过在我的Test项目中放置一个hibernate.cfg.xml文件来修复问题映射实体。


 public sealed class NHibernateHelper
{
    private static ISessionFactory _sessionFactory;
    const string Connectionstring = "servicestring";

    public static void OpenSession()
    {      
        var config = new Configuration();                        
        config.Configure();
        config.AddAssembly(Assembly.GetCallingAssembly());    
        _sessionFactory = config.BuildSessionFactory();

    }

    public static ISession GetCurrentSession()
    {
        ISession session = null; 
        if (_sessionFactory == null)
            OpenSession();

        if (_sessionFactory != null)
        {
            session = _sessionFactory.OpenSession();
        }

        return session;
    }

    public static void CloseSessionFactory()
    {
        if (_sessionFactory != null)
        {
            _sessionFactory.Close();
        }
    }


    // var dsn = ConfigurationManager.ConnectionStrings[Connectionstring].ConnectionString;
    //config.SessionFactory().Integrate.Using<MsSqlCeDialect>().Connected.ByAppConfing(dsn);
    // System.Diagnostics.Debug.WriteLine("My connection string: "+dsn);
    //Get NHibernate configuration 
    //_sessionFactory = config.BuildSessionFactory();  
    //config.AddAssembly("HibernateExample");
}

有什么想法吗?

    <?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="hibernate-configuration" type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate" />
  </configSections>
  <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2" >
    <session-factory>
      <property name="connection.driver_class"> NHibernate.Driver.SqlServerCeDriver</property>
        <property name="dialect">NHibernate.Dialect.MsSqlCeDialect</property>
      <property name="connection.connection_string">Data Source=FirstSample.sdf;</property>
      <property name="show_sql">true</property>
      <mapping assembly="HibernateExample"/>
    </session-factory>
  </hibernate-configuration>


  <connectionStrings>
        <add name="testconnectionstring"
            connectionString="Data Source=|DataDirectory|\FirstSample.sdf;Integrated Security=True"
            providerName="Microsoft.SqlServerCe.Client.3.5" />
    </connectionStrings>

  <runtime>
    <assemblyBinding xmlns="urnchemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="System.Data.SqlServerCe" publicKeyToken="89845DCD8080CC91" culture="neutral"/>
        <bindingRedirect oldVersion="0.0.0.0-9.0.242.0" newVersion="3.5.0.0"/>
      </dependentAssembly>
    </assemblyBinding>

  </runtime>
</configuration>

  <?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="HibernateExample" namespace="HibernateExample.Domain" >
  <class name="Product" table="Products">
    <id name="Id" type="integer">
      <generator class="identity"/>
    </id>
    <property name="Name" type="string"/>
    <property name="Category" type="string"/>
    <property name="Discontinued" />
  </class>
</hibernate-mapping>

异常抛出:

    Test 'NunitTest.TestClass.canquerydb' failed: NHibernate.MappingException : Could not compile the mapping document: HibernateExample.Mappings.Products.hbm.xml
  ----> System.InvalidOperationException : Could not find the dialect in the configuration
    at NHibernate.Cfg.Configuration.LogAndThrow(Exception exception)
    at NHibernate.Cfg.Configuration.AddDeserializedMapping(HbmMapping mappingDocument, String documentFileName)
    at NHibernate.Cfg.Configuration.ProcessMappingsQueue()
    at NHibernate.Cfg.Configuration.AddInputStream(Stream xmlInputStream, String name)
    at NHibernate.Cfg.Configuration.AddResource(String path, Assembly assembly)
    at NHibernate.Cfg.Configuration.AddAssembly(Assembly assembly)
    at NHibernate.Cfg.Configuration.AddAssembly(String assemblyName)
    NHibernateTest\NHibernateHelper.cs(21,0): at HibernateExample.NHibernateTest.NHibernateHelper.openSession()
    NHibernateTest\NHibernateHelper.cs(28,0): at HibernateExample.NHibernateTest.NHibernateHelper.GetCurrentSession()
    TestClass.cs(21,0): at NunitTest.TestClass.canquerydb()
    --InvalidOperationException
    at NHibernate.Dialect.Dialect.GetDialect(IDictionary`2 props)
    at NHibernate.Cfg.Configuration.AddDeserializedMapping(HbmMapping mappingDocument, String documentFileName)

1 个答案:

答案 0 :(得分:1)

从错误中看,在添加映射之前,您似乎没有配置Dialect。这是必需的。

这是一个简单的基本配置代码:

var configuration = new Configuration();
configuration.SessionFactory().Integrate.Using<MsSql2012Dialect>()
                                        .Connected.ByAppConfing("connName");//sic
//now you can add the mappings
相关问题