Мы используем Fluent NHibernate для модели объектов данных в компании, в которой я работаю. Пару дней назад мы столкнулись с проблемой, что Fluent NHibernate генерирует дополнительный столбец, который не существует ни в модели, ни в сопоставлении. Вот ситуация:Fluent NHibernate генерирует дополнительные столбцы
My Model: FirstClass.cs
public class FirstClass
{
public virtual int Id { get; private set; }
public virtual SecondClass MyReference { get; set; }
public virtual DateTime DecisionDate { get; set; }
}
Мой Mapping:
public class FirstClassMap : ClassMap<FirstClass>
{
public FirstClassMap()
{
Id(x => x.Id);
Map(x => x.DecisionDate);
References(x => x.MyReference);
}
}
После построения схемы с помощью следующего кода,
Instance._sessionFactory = Fluently.Configure()
.Database(MySQLConfiguration.Standard
.ConnectionString(connectionString)
.ShowSql())
.ExposeConfiguration(c =>
{
c.Properties.Add("current_session_context_class", ConfigurationHelper.getSetting("SessionContext"));
})
.ExposeConfiguration(BuildSchema)
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<Community>())
.BuildSessionFactory();
Дополнительный столбец с именем «SecondClass_id» создается с индексом и внешним ключом в таблице SecondClass с столбцом Id. Вот таблица производства:
CREATE TABLE `FirstClass` (
`Id` int(11) NOT NULL AUTO_INCREMENT,
`DecisionDate` datetime DEFAULT NULL,
`MyReference_id` int(11) DEFAULT NULL,
`SecondClass_id` int(11) DEFAULT NULL,
PRIMARY KEY (`Id`),
KEY `MyReference_id` (`MyReference_id`),
KEY `SecondClass_id` (`SecondClass_id`),
CONSTRAINT `FK4AFFB59B2540756F` FOREIGN KEY (`MyReference_id`) REFERENCES `SecondClass` (`Id`),
CONSTRAINT `FK4AFFB59B51EFB484` FOREIGN KEY (`SecondClass_id`) REFERENCES `SecondClass` (`Id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Я обнаружил, что, если я переименовать «MyReference» в «SecondClass» (такое же имя как тип класса), нет никакой дополнительной колонки создана. Но я хочу использовать свое свойство с указанным именем, а не с именем класса. Почему этот дополнительный столбец создан? Как это исправить? Я не хочу, чтобы на нем висели дополнительные столбцы внешнего ключа.
Вы имеете в виду, если вы измените имя свойства, отличное от имени объекта, оно создает два поля, одно из которых - ваше_отображение другое - имя_объекта? – gandil
Определенно. Любые идеи почему? – SadullahCeran
Звучит странно. Что произойдет, если вы явно укажете имя столбца. Ссылки (x => x.MyReference, "SecondClass_id"); –