Сообщение об ошибке:
Оператор INSERT конфликтовал с ограничением FOREIGN KEY «FK_UserProfile_UserLogin». Конфликт произошел в базе данных "ToDoDB", таблице "dbo.UserLogin", столбце "UserLoginID". Заявление было прекращено.
Что это может означать?
Я пытаюсь создать простое веб-приложение для входа и профиля MVC5.  Я создал свою таблицу в SQL Express.
Во-первых, вот моя модель страницы регистрации:
public class UserSignUp
{
    [Key]
    public int UserLoginID { get; set; }
    //Foregin key for the login table - First name, last name, creation date, and email
    public int UserProfileID { get; set; }
    [Required(ErrorMessage = "Username is required")]
    [Display(Name = "Username")]
    public string Username { get; set; }
    [Required(ErrorMessage = "Password is required")]
    [Display(Name = "Password")]
    public string Password { get; set; }
    [Required(ErrorMessage = "First Name is required")]
    [Display(Name = "First Name")]
    public string FirstName { get; set; }
    [Required(ErrorMessage = "Last Name is required")]
    [Display(Name = "Last Name")]
    public string LastName { get; set; }
    [DataType(DataType.DateTime)]
    public DateTime CreationDate { get; set; }
    [Required(ErrorMessage = "Valid email is required")]
    [DataType(DataType.EmailAddress)]
    public string Email { get; set; }
}
Таким образом, UserLoginID — это первичный ключ из таблицы UserLogin, а UserProfileID — это первичный ключ из таблицы UserProfile.  Я установил внешний ключ таблицы UserProfile на UserLoginID из таблицы UserLogin.
Вот моя модель создания нового пользователя:
public class UserProfileManager
{
    public void AddUserAccount(UserSignUp newUser)
    {
        // create database connection
        using (ToDoDBEntities db = new ToDoDBEntities())
        {
            // Collect viewmodel data
            // Here building goes by object type and not foregin key relationship
            UserLogin UL = new UserLogin();
            UL.Username = newUser.Username;
            UL.Password = newUser.Password;
            // Add the UserLogin object I just built to the database
            db.UserLogins.Add(UL);
            db.SaveChanges();
            UserProfile UP = new UserProfile();
            // establish connection to UL by establishing foreign key relationship
            UP.UserLoginID = newUser.UserLoginID;
            UP.FirstName = newUser.FirstName;
            UP.LastName = newUser.LastName;
            UP.CreationDate = newUser.CreationDate;
            UP.Email = newUser.Email;
            // Add UserProfile object to databse and save changes
            db.UserProfiles.Add(UP);
            db.SaveChanges();
        }
    }
    //Check if user is real before login is allowed
    public bool isLoginReal(string LoginName)
    {
        using (ToDoDBEntities DB = new ToDoDBEntities())
        {
            // Return the user from the DB whose login name matches the LoginName string passed in as perameter
            return DB.UserLogins.Where(o => o.Username.Equals(LoginName)).Any();
        }
    }
}
Мой AddUserAccount — это место, где, как мне кажется, у меня проблемы.  Итак, я начинаю с создания объекта UserLogin, добавления и сохранения в базе данных.  Кажется, это действительно работает.  Но следующий шаг, когда я создаю, добавляю и сохраняю объект UserProfile, похоже, не работает.  По крайней мере, база данных не обновляется.
Вот контроллер, обрабатывающий действия:
public class AccountController : Controller
{
    // GET: Account
    public ActionResult Index()
    {
        return View();
    }
    #region signup methods
    // Get method for signup page
    public ActionResult SignUpPage()
    {
        return View();
    }
    // Post method for signup page - post to db
    [HttpPost]
    // Pass in the UserSign up model object to be built
    public ActionResult SignUpPage(UserSignUp USUV)
    {
        // Form is filled out and then method is entered
        if (ModelState.IsValid)
        {
            // Form is filled out and database connection is established if form is valid
            UserProfileManager UPM = new UserProfileManager();
            if (!UPM.isLoginReal(USUV.Username))
            {
                // data access . adduseraccount from entity manager (where model objects are built)
                UPM.AddUserAccount(USUV);
                FormsAuthentication.SetAuthCookie(USUV.FirstName, false);
                return RedirectToAction("Welcome", "Home");
            }
            else
            {
            }
        }
        return View();
    }
    #endregion
}
На мой (нубский) взгляд все выглядит хорошо.  Получен SignUpPage, затем новый объект UserSignUp передается в действие Post, строится объект Entity Framework (UserProfileManager), форма аутентифицируется, и пользователь либо перенаправляется в представление Welcome, либо пользователь возвращается в представление регистрации  .
Есть ли шанс, что кто-то может помочь мне понять, что я упускаю или делаю неправильно? Я включил изображение дизайна базы данных для справки (я знаю о базе данных еще меньше, чем MVC).

 
                                                                     
                                                                     
                                                                     
                                                                    