Хобрук: Ваш путь к мастерству в программировании

Вставка Linq 2 Sql без отношения

У меня 2 стола. например: один из них предназначен для хранения пользователей, а другой - для хранения заказов. Таблица заказов, содержащая UserId в качестве внешнего ключа. Я использую Linq 2 Sql для операций доступа к данным. Я хочу вставить заказ без вставки строки пользователя, если пользователь уже существует в базе данных.

Как я могу это сделать?

Заранее спасибо,

Изменить: вот код, с которым у меня проблемы:

try
{
    context.SocialEntities.InsertOnSubmit(entity);
    context.SubmitChanges();
}
catch (Exception ex)
{
    if (ex.Message.Contains("UserUniqueness"))
    {                     
        User user = context.Users.Where(u => u.SourceUserID == entity.User.SourceUserID).FirstOrDefault();
        if (user != null)
        {
            user.SocialEntities.Add(entity);
            context.SubmitChanges();
        }
    }
}

UserUniqueness — это уникальное ключевое ограничение, определенное в таблице User для столбца с именем SocialSourceId. И это не первичный ключ.

17.05.2011

Ответы:


1

Добавьте новый заказ в коллекцию Orders существующего пользователя.

ОБНОВЛЕНИЕ:
я предлагаю вам проверить пользователя, прежде чем пытаться его вставить. Я предполагаю, что пользователь, которого вы пытались добавить каким-то образом, все еще находится в вашем контексте и снова отправляется при следующем вызове SubmitChanges.

17.05.2011
  • Он по-прежнему говорит: нарушение ограничения UNIQUE KEY «UserUniqueness». Не удается вставить повторяющийся ключ в объект «dbo.User». Пользовательская таблица имеет уникальное ключевое ограничение 17.05.2011
  • Что вы делаете с пользователем? Пожалуйста, отредактируйте свой вопрос и укажите код. 17.05.2011
  • Это больше не поможет, извините. Я предлагаю вам проверить пользователя, прежде чем пытаться его вставить. Я предполагаю, что пользователь, которого вы пытались добавить каким-то образом, все еще находится в вашем контексте и снова отправляется при следующем вызове SubmitChanges. 17.05.2011
  • Вот в чем проблема! Ты прав! Большое спасибо!. Я приму ваш ответ, вы можете обновить его! 17.05.2011
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

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

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

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..