所以我有一个 Post 和 Tag 类,它们应该是多对多的。但是我无法显示任何标签。
课后
public class Post
{
public Post()
{
this.Tags = new List<Tag>();
}
public int PostID { get; set; }
public string Title { get; set; }
public DateTime DateTime { get; set; }
public string Body { get; set; }
public virtual IList<Tag> Tags { get; set; }
}
标签类:
public class Tag
{
public int TagID { get; set; }
public string Name { get; set; }
public virtual ICollection<Post> Posts { get; set; }
}
还有我的 Controller 的一部分
[HttpPost]
public ActionResult Create([Bind(Include = "Title,Body,Tags")] BlogInputModel input)
{
if (ModelState.IsValid)
{
Post post = new Post
{
Title = input.Title,
Body = input.Body,
DateTime = DateTime.Now
};
post.Tags.Clear();
foreach (string tag in input.Tags.Split(' '))
{
post.Tags.Add(GetTag(tag));
}
db.Posts.Add(post);
db.SaveChanges();
return RedirectToAction("Details", new { id = post.PostID });
}
return RedirectToAction("Index");
}
public ActionResult Details(int id)
{
var post = db.Posts.Where(x => x.PostID == id).First();
return View(post);
}
private Tag GetTag(string tagName)
{
return db.Tags.Where(x => x.Name == tagName).FirstOrDefault() ?? new Tag { Name = tagName };
}
这是我的上下文类
public class BlogContext : DbContext
{
public BlogContext() : base("BlogContext")
{
}
public DbSet<Post> Posts { get; set; }
public DbSet<Tag> Tags { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Post>()
.HasMany(t => t.Tags)
.WithMany(p => p.Posts)
.Map(m => m.MapLeftKey("PostID")
.MapRightKey("TagID")
.ToTable("PostTags"));
}
}
我尝试修复它时遇到异常,但没有任何效果。 EF 不应该只创建 PostTags 表并且一切都应该连接吗?
或者我是否必须摆脱 modelBuilder 代码并创建我自己的第三个表,但如果是这样,我如何将帖子的 ID 传递给标签?
最佳答案
Shouldn't EF just create the PostTags table and everything should connect?
Or do I have to get rid of the modelBuilder code and create my own third table, but if so, how can I pass the ID of a post to the tags?
EF 足够聪明,知道需要一个新表来链接 Tag
和 Post
因为你创造了:
-
IList<Tag>
在Post
-
ICollection<Post>
在Tag
.
然后你可以删除你在OnModelCreating
中写的代码EF 将创建一个新表来链接 Tag
和 Post
.
删除 OnModelCreating
中代码的缺点是:
- 您事先不知道 EF 将如何命名您的表
PostTags
或TagPosts
.想象一下,您需要创建一个与链接表相关的 SQL View ,知道表的名称会很酷。 - 您不知道组合键在创建时的顺序是什么,因为您在使用
DbSet.Find
时需要使用相同的顺序。方法。此方法需要键的顺序与它们在链接表上的创建顺序相同。
关于c# - 如何为帖子添加标签?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33602577/