Db.savechanges сохраняет запись дважды

У меня есть следующий статус foreach

foreach (var e in empList)
        {
            db.EmployeeForecasts.Add(e);
            db.SaveChanges();
        }

EmpList содержит только 1 запись, но db.SaveChanges () дважды сохраняет запись в базе данных?

Может кто-нибудь объяснить, почему это происходит и что я могу с этим поделать? Спасибо!

Не могли бы вы опубликовать некоторые подробности о типах empList и всей функции в целом? Уверены, что его вызывают только один раз?

mororo 16.11.2018 19:21

Вы должны использовать SQL Server Profiler и отладчик VS, чтобы узнать, на каком этапе дублируется запись.

JohnyL 16.11.2018 19:23

Есть ли в empList повторяющиеся записи?

Gabriel Luci 16.11.2018 19:28

это не ответ на ваш вопрос, но вы должны сохранить изменения после закрытия цикла. и вы также можете использовать AddRange(empList)

Ashkan Mobayen Khiabani 16.11.2018 19:29

Измените свой вопрос, включив в него MCVE, который может быть скомпилирован и протестирован другими, что показывает, что добавляются дубликаты.

Progman 16.11.2018 19:51

В empList есть только одна запись. Контроллер - это сборник форм, до этого работал отлично и вдруг дважды сохраняет запись? Можно ли проверить db.EmployeeForecast, чтобы увидеть, добавлена ​​ли запись дважды?

Thijs 17.11.2018 18:39

Я также пытался спасти его, добавив хранимую процедуру. Но тот же результат, он сохраняет запись дважды?

Thijs 17.11.2018 18:47

Я пробовал с AddRange, но результат тот же, запись сохранена дважды.

Thijs 17.11.2018 18:51
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
8
434
2

Ответы 2

Скорее всего, ваша база данных уже содержит сущность. Вместо использования добавления вы должны посмотреть на

foreach (var e in empList)
        {
            db.EmployeeForecasts.Attach(e);
    }
db.SaveChanges();

Это интересно, вы создали экземпляр контекста db непосредственно перед foreach? Можете ли вы использовать его, чтобы мы были уверены, что он запускает только ваш маленький кусочек трески с Add.

Aldert 17.11.2018 19:30

Извините, это была глупая ошибка. Я использую JQuery для отправки формы, но дважды вызывал контроллер. Таким образом, очевидно, что запись была сохранена дважды. Спасибо за помощь.

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