c# - 如何从 POST 插入多行

标签 c# mysql asp.net-mvc

我有一个包含 n 个输入字段的 View (数量会根据不同的条件而变化)。每个输入字段的值需要插入到数据库中各自的行中。 我的问题是只有第一个输入字段被插入到数据库中。 Controller 看起来像这样:

public ActionResult Create([Bind(Include = "Id,MemberId,Rated,Rating")] Rating rating)
        {
                if (ModelState.IsValid)
                {
                    db.Ratings.Add(rating);
                    db.SaveChanges();                  
                }

每一行的MemberId值相同,但Rated和Rating会不同。

我的模型如下所示:

[Table("Rating")]
    public partial class Rating
    {
        public int Id { get; set; }

        public int? MemberId { get; set; }

        public int Rated { get; set; }

        [Column("Rating")]
        public int Rating { get; set; }

        public virtual TeamMember TeamMember { get; set; }
    }

View 如下所示:

@model Teamer.Models.Rating

@{
    ViewBag.Title = "Create";
}

<h2>Create</h2>

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        <h4>Rating</h4>
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })

        <div class="form-group">
            @{
                int count = 0;

                foreach (var item in ViewBag.MemberId)
                {
                    string rater = Request.Cookies["rater"]["name"].ToString();
                    string raterId = Request.Cookies["rater"]["raterId"];

                    if (item.Name.ToLower() != rater.ToLower())
                    {
                        if (ViewBag.raterId != null)
                        {
                            foreach (var raterid in ViewBag.raterId)
                            {
                                <input type="hidden" name="MemberId" value="@raterid" />
                            }
                        }
                        <div class="col-md-10">
                            <label class="control-label col-md-2" for="@item.Name">@item.Name</label>
                            <input type="number" name="Rating-@count" value="0" />
                            <input type="hidden" name="Rated" value="@item.Id" />
                        </div>  
                        count++;
                    }
                }
            }
        </div>

        <input type="hidden" name="count" value="@count" />

        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Create" class="btn btn-default" />
            </div>
        </div>
    </div>
}

我猜,我需要逐一循环这些值,但我无法让它工作,所以也许我在这方面还很遥远。

编辑

好的,所以我现在可以使用简单的解决方案(尽管可能有点难看)来解决它。 我的 Controller 现在看起来像这样:

public ActionResult Create(Rating rating)
        {
            int count = int.Parse(Request.Form["count"]);

            for (int i = 0; i < count; i++)
            {
                string test = Request.Form["MemberId"];
                rating.MemberId = int.Parse(test);
                rating.Rated = int.Parse(Request.Form["Rated-" + i]);
                rating.Rating1 = int.Parse(Request.Form["Rating1-" + i]);
                db.Ratings.Add(rating);

                if (ModelState.IsValid)
                {
                    db.SaveChanges();
                }
            }

            return RedirectToAction("Index");

        }

我的观点:

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()

<div class="form-horizontal">
    <h4>Rating</h4>
    <hr />
    @Html.ValidationSummary(true, "", new { @class = "text-danger" })

    <div class="form-group">
        @{
            int count = 0;
            string raterId = Request.Cookies["rater"]["raterId"];
            foreach (var item in ViewBag.MemberId)
            {
                string rater = Request.Cookies["rater"]["name"].ToString();


                if (item.Name.ToLower() != rater.ToLower())
                {

                    <div class="col-md-10">
                        <label class="control-label col-md-2" for="@item.Name">@item.Name</label>
                        <input type="number" name="Rating1-@count" value="0" />
                        <input type="hidden" name="Rated-@count" value="@item.Id" />
                    </div>

                    count++;
                }

            }
        }
    </div>

    <input type="hidden" name="MemberId" value="@raterId" />

    <input type="hidden" name="count" value="@count" />

    <div class="form-group">
        <div class="col-md-offset-2 col-md-10">
            <input type="submit" value="Create" class="btn btn-default" />
        </div>
    </div>
</div>
}

这很简单,但我感觉还有更好、更简洁的方法。有什么建议吗?

最佳答案

我可以看到一些问题,但最终,您没有发布 Controller 所期望的内容。您的 Controller 期望获得Rating(因此 Id、MemberId、Rated 和 Rating),但您实际上发布了类似

MemberId=raterId (repeated by as many ViewBag.raterId you have)
Rating-0=0
Rated=memberX_Id
Rating-1=0
Rated=memberY_Id
Rating-2=0
Rated=memberZ_Id
(...)
Rating-n=0
Rated=memberM_Id
count=(n+1)

如果您检查您发布的数据,您应该只填写了 MemberId 和 Rated。

为了实现您想要的目标,您需要在 Controller 端有一个 Rating 列表或不同的结构。请记住,如果您想发布一个数组,它应该类似于

MemberId[0]=
Rated[0]=
Rating[0]=
MemberId[1]=
Rated[1]=
Rating[1]=
(...)
MemberId[n]=
Rated[n]=
Rating[n]=

另请注意,MemberId 和 Rated 在循环中会被覆盖。

关于c# - 如何从 POST 插入多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59120192/

相关文章:

MySQL存储过程初学者错误

javascript - Html.ActionLink 在 html 选项标签中不起作用

asp.net-mvc - 如何从 System.Drawing.Bitmap 类型提供图像(<img> 标记?)

c# - 我如何将参数从javascript传递到控件vb.net中的隐藏字段

c# - 在 eval 中使用代码隐藏函数

c# - MailItem SaveAs() 方法文件类型

php - 如何计算具有匹配 ID 的行数?

mysql - 插入数据库日期时间字符串

c# - MVC ASP.Net 上的 session 锁定 - 防止用户同时访问同一资源

c# - Math.Round() 似乎不一致