NHibernate use Firebird own generator

≯℡__Kan透↙ 提交于 2019-12-11 01:47:12

问题


Having own generator in Firebird DB called GEN_PATIENT_ID I would like to leave the generation of ID on the DB side instead of NHibernate and FluentNHibernate. Following this link I am overriding the default Fluent behavior like this:

public class PatientOverride : IAutoMappingOverride<Patient>
    {
        public void Override(AutoMapping<Patient> mapping)
        {
            mapping.Cache.ReadOnly().Region("LongTermReadWrite");
            mapping.Id(x => x.Id).GeneratedBy.Sequence("GEN_PATIENT_ID");
            mapping.HasOne(patient => patient.Tag).Not.LazyLoad().Cascade.All();
        }
    }

However I still get an error because NHibernate is trying to generate its own:

{"Dynamic SQL Error\r\nSQL error code = -204\r\nTable unknown\r\nHIBERNATE_UNIQUE_KEY\r\nAt line 1, column 42"}

Doublechecked if I am importing the overrides and it should be OK:

mappings.UseOverridesFromAssemblyOf<AutoPersistenceModelGenerator>();

the save is pretty much standard:

var patient = patientDtoMapper.MapFrom(patientDto);

using (ITransaction t = NHibernateSession.Current.BeginTransaction())
{
    patientRepository.Save(patient);                
    t.Commit();
}

Any ideas?

来源:https://stackoverflow.com/questions/48559427/nhibernate-use-firebird-own-generator

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!