Модульное тестирование NHibernate Postgresql с SQLite. Задача генератора последовательностей

Можно ли сделать генератор идентификаторов Sqlite NHibernate совместимым с Postgresql? Я планирую провести модульное тестирование своего проекта NHibernate Postgresql на основе этого http://ayende.com/Blog/archive/2009/04/28/nhibernate-unit-testing.aspx

Если нет совместимого генератора идентификаторов, есть ли способ сообщить NHibernate, чтобы он игнорировал генератор идентификаторов, когда он использует другой диалект?

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" auto-import="true" assembly="RuntimeNhibernate" namespace="RuntimeNhibernate" >

  <class name="Blog" table="blog">
    <id name="BlogId" column="blog_id">
        <!-- can this be ignored when using different dialect.. -->
        <generator class="sequence"> 
            <param name="sequence">blog_id_seq</param>
        </generator> 
        <!-- ...can this -->
    </id>


    <property name="AllowsComments" column="allows_comments"/>
    <property name="CreatedAt" column="created_at"/>
    <property name="Subtitle" column="subtitle"/>
    <property name="Title" column="title"/>


  </class>

</hibernate-mapping>  

Ошибка при использовании диалекта Sqlite в отображении, специфичном для Postgresql:

NHibernate.MappingException: could not instantiate id generator: sequence ---> 
NHibernate.MappingException: Dialect does not support sequences

1 ответ

Решение

Я предлагаю вам использовать генератор, независимый от БД, например, HiLo,

Другие вопросы по тегам