0

次のようなエラーが発生しました。

INSERTステートメントがFOREIGNKEY制約「FK_dbo.Comments_dbo.Posts_PostID」と競合しました。データベース「MVCProjectApp.Models.DBPostsContext」、テーブル「dbo.Posts」、列「PostID」で競合が発生しました。
ステートメントは終了されました。

私は道に迷い、何をすべきかわからない

これが作成コメントです

@model MVCProjectApp.Models.Comment

@{
    ViewBag.Title = "Create Comment";
}

<h2>Create</h2>

@using (Html.BeginForm()) {
    @Html.ValidationSummary(true)

    <fieldset>
        <legend>Comments</legend>

        <div class="editor-label">
            @Html.LabelFor(model => model.Username)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Username)
            @Html.ValidationMessageFor(model => model.Username)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Message)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Message)
            @Html.ValidationMessageFor(model => model.Message)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Timestamp)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Timestamp)
            @Html.ValidationMessageFor(model => model.Timestamp)
        </div>


        <p>
            <input type="submit" value="Create" />
        </p>
    </fieldset>
}

<div>
    @Html.ActionLink("Back to List", "~/FullPost/Index")
</div>

@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}

これは、postidをコメント作成に渡すActionlinkです。

//
        // GET: /Comment/Create

        public ActionResult Create()
        {
            ViewBag.PostID = new SelectList(db.Posts, "PostID", "Title");
            return View();
        }

        //
        // POST: /Comment/Create

        [HttpPost]
        public ActionResult Create(Comment comment)
        {
            if (ModelState.IsValid)
            {
                db.Comments.Add(comment);
                db.SaveChanges();
                return RedirectToAction("Index");
            }

            ViewBag.PostID = new SelectList(db.Posts, "PostID", "Title", comment.PostID);
            return View(comment);
        }

これがコメントモデルです

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace MVCProjectApp.Models
{
    public class Post
    {
        public int PostID { get; set; }
        public string Title { get; set; }
        public string Message { get; set; }
        public DateTime Timestamp { get; set; }
        public virtual ICollection<Comment> Comments { get; set; }
    }
    public class Comment
    {
        public int CommentID { get; set; }
        public int PostID { get; set; }
        public string Username { get; set; }
        public string Message { get; set; }
        public DateTime Timestamp { get; set; }
        public virtual Post Post { get; set; }
    }
}
4

2 に答える 2

1

道に迷ってどうすればいいのかわからない

発生しているエラーを確認する必要があります。コメントを挿入しようとしていると表示されます。挿入の前に DBMS によって実行される外部キー制約チェックは、コメントが認識している PostID を持っていることを確認しようとします。設定しないため、デフォルトで 0 になります。これは Posts テーブルに存在しないため、エラーが発生します。

ビューにフィールドをSaveChanges()追加することで、 を呼び出す前にコメントの PostID を設定する必要があります。@Html.HiddenFor(m => m.PostID)次に、コントローラーでモデルの PostID を設定します。

于 2012-12-05T14:13:05.683 に答える
0

コメントを投稿に関連付ける必要があります。最も簡単な解決策は、投稿 ID の非表示フィールドをビューに追加することです。

于 2012-12-05T14:13:46.523 に答える