Один из предложенное предложение звучит хорошо. Ниже приведено это решение.
Код: Выделить всё
///
/// https://github.com/dotnet/efcore/issues/30488
///
public class AllowSameColumnMultiplePropertiesRelationModelValidator(ModelValidatorDependencies dependencies, RelationalModelValidatorDependencies relationalDependencies) : RelationalModelValidator(dependencies, relationalDependencies)
{
protected override void ValidateSharedColumnsCompatibility(IReadOnlyList mappedTypes, in StoreObjectIdentifier storeObject, IDiagnosticsLogger logger)
{
try
{
base.ValidateSharedColumnsCompatibility(mappedTypes, storeObject, logger);
}
catch (InvalidOperationException ex)
{
var exIsColumnIsAssignedToMoreThanOneProp = ex.Message.Contains("are both mapped to column", StringComparison.OrdinalIgnoreCase) &&
ex.Message.Contains("but the properties are contained within the same hierarchy", StringComparison.OrdinalIgnoreCase);
if (!exIsColumnIsAssignedToMoreThanOneProp)
throw;
}
}
}
примечание: я знаю, что столбец не может быть сопоставлен с двумя свойствами. в той же иерархии. Но это устаревший код. Эффект от удаления выше. Вот почему мы пытаемся подавить эту ошибку.
Подробнее здесь: https://stackoverflow.com/questions/792 ... -own-class