ASP.NET MVC:使用LINQ To SQL将表单复选框转换为多对多DB关联表的最佳方法?
-
03-07-2019 - |
题
我有一个ASP.NET MVC视图,其中包含用户定义类别的复选框。
<td><% foreach (Category c in (List<Category>)ViewData["cats"]) {
if (selCats.ContainsKey(c.ID)) { %>
<input name="CategoryIDs" type="checkbox" value="<%=c.ID %>" checked="checked" /> <%= c.Name%><% }
else { %>
<input name="CategoryIDs" type="checkbox" value="<%=c.ID %>" /> <%= c.Name%> <% } %>
<% } %>
</td>
表单将发布到以下控制器操作:
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Edit(int id, int [] CategoryIDs)
{
PostsDataContext db = new PostsDataContext();
var post = db.Posts.Single(p => p.ID == id);
UpdateModel(post, new[] { "Title", "Subtitle", "RawContent", "PublishDate", "Slug" });
db.SubmitChanges();
return Redirect("/archives/" + post.Slug);
}
表单复选框将转换为整数ID“CategoryID”的数组,每个表示所选类别。然后我想把它们放到一个包含两列的关联表中:PostID和CategoryID。这用于在帖子和类别之间建立多对多关联。
目前,我正在强制它:循环遍历类别,并为每个类别添加一行到包含类别ID的关联表,以及它所属的帖子的ID。
但是我想知道在ASP.NET MVC和LINQ to SQL的上下文中是否有更简洁的方法来自动执行此操作?
谢谢!
解决方案
我认为你正在做的事情很好......我唯一要说的是,如果你不想循环使用ID,你可以在同时使用“InsertAllOnSubmit”添加它们。 (即使这也只是循环):
int[] categoryIDs = new int[] { 0, 1, 2 };
dataContext.PostCategories.InsertAllOnSubmit(
categoryIDs.Select(id =>
new PostCategory
{
CategoryID = id,
PostID = myPostID
})
);
但无论如何,这仍然和你所做的一样。
不隶属于 StackOverflow