gpt4 book ai didi

c# - 如何从 POST 插入多行

转载 作者:行者123 更新时间:2023-11-29 15:25:23 24 4
gpt4 key购买 nike

我有一个包含 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com