Entity Framework UpdateException отношения в добавленном и удаленном состояниях
У меня есть таблица растений и информации.
У растений есть ID, Имя, ..., MainInformationID
Информация имеет идентификатор, название, ..., PlantID
Одно растение может иметь много информации, но только одна основная информация. Информация может иметь только одно растение.
У меня есть класс ViewModel, который содержит наблюдаемые коллекции растений и информацию, которая привязана к окну.
Когда я пытаюсь изменить основную информацию о растении. Я получаю эту ошибку:
Отношение из AssociationSet 'FK_Plants_Information' находится в состоянии "Добавлено". Учитывая ограничения множественности, соответствующая "Информация" также должна находиться в состоянии "Добавлено".
Если я выбираю информацию, которая не используется на каком-либо заводе, она говорит о состоянии "Добавлен", а если я выбираю ту, которая используется, она говорит о состоянии "Удален".
**class PlantsViewModel : ViewModelBase
{
private DAL _dal = new DAL();
private ObservableCollection<Plant> _plants = new ObservableCollection<Plant>();
public ObservableCollection<Plant> Plants
{
get { return _plants; }
set
{
_plants = value;
_OnPropertyChanged("Plants");
}
}
private Plant _selectedPlant;
public Plant SelectedPlant
{
get { return _selectedPlant; }
set
{
_selectedPlant = value;
_OnPropertyChanged("SelectedPlant");
}
}
private ObservableCollection<Information> _information = new ObservableCollection<Information>();
public ObservableCollection<Information> Information
{
get { return _information; }
set
{
_information = value;
_OnPropertyChanged("Information");
}
}
}
И окно:
<TextBox Grid.Column="1" Grid.Row="0" Width="150" Text="{Binding Path=SelectedPlant.LatinName}" />
<TextBox Grid.Column="1" Grid.Row="1" Width="150" Text="{Binding Path=SelectedPlant.LocalName}" />
<TextBox Grid.Column="1" Grid.Row="2" Width="150" Text="{Binding Path=SelectedPlant.CycleTime}" />
<ComboBox Grid.Column="1" Grid.Row="3" Width="150" ItemsSource="{Binding Path=Information}"
DisplayMemberPath="Title"
SelectedValue="{Binding Path=SelectedPlant.MainInformation, Mode=TwoWay}" />
DAL выглядит так.
public class DAL {
private static Entities _context = new Entities();
public void SaveChanges()
{
_context.SaveChanges();
}
public List<Plant> GetAllPlants()
{
return _context.Plants.ToList();
}
public void AddNewPlant(Plant plant)
{
_context.Plants.AddObject(plant);
}
public void DeletePlant(Plant plant)
{
_context.DeleteObject(plant);
}
}
Также, пожалуйста, скажите мне, есть ли здесь что-нибудь, что не кажется хорошей идеей (например, наличие статического контекста, способ подключения моей viewModel к dal и так далее... (Я новичок, поэтому я не действительно не знаю, как его правильно использовать)
1 ответ
Ошибка говорит о том, что у вас отсутствует обязательное поле. Я предполагаю, что это MainInformation
, Вы могли бы сделать что-то вроде:
Dal.AddPlant(new Plant { MainInformation = new Information() });
Да, это плохая идея использовать статический контекст. В этом посте обсуждается, как выбрать подходящее время жизни.