1

我正在使用 Entity Framework 4 和 C# 创建一个 MVC3 asp.net 应用程序。

我试图阅读 EF 和模型绑定、延迟加载等。但我遇到了障碍。

我有一个用户模型。Store 和 UserType 模型可以有一个用户的 ICollection。当我使用创建操作添加用户时,如何指定多个父级?

我想我只知道如果有一个父母,我该怎么添加。

我的模型:

 public class UserType
{
    public virtual int ID { get; set; }
    public virtual string UserTypeName { get; set; }
    public virtual ICollection<User> Users { get; set; }
}

public class Store
{
    public virtual int ID { get; set; }
    public virtual string StoreName { get; set; }
    public virtual Address StoreAddress { get; set; }
    public virtual ICollection<Workroom> Workrooms { get; set;}
    public virtual ICollection<User> Users { get; set; }
}

    public class User
{
    public virtual int ID { get; set; }
    public virtual string Username { get; set; }
    public virtual string Email { get; set; }
    public virtual Store Store { get; set; }
    public virtual UserType UserType { get; set; }
}

这是我的数据库上下文:

    public DbSet<Workroom> Workrooms { get; set; }
    public DbSet<Ticket> Tickets { get; set; }
    public DbSet<Customer> Customers { get; set; }
    public DbSet<Store> Stores { get; set; }
    public DbSet<User> Users { get; set; }
    public DbSet<UserType> UserTypes { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<Store>()
            .HasMany(store => store.Workrooms)
            .WithRequired(workroom => workroom.Store);

        modelBuilder.Entity<Store>()
            .HasMany(store => store.Users)
            .WithRequired(user => user.Store);

        modelBuilder.Entity<UserType>()
            .HasMany(usertype => usertype.Users)
            .WithRequired(user => user.UserType);

        base.OnModelCreating(modelBuilder);
    }

这是我的创建操作:

    public ActionResult Create()
    {
        return View(new User());
    } 

    //
    // POST: /Users/Create

    [HttpPost]
    public ActionResult Create(User newUser)
    {
        try
        {
            int storeID = newUser.Store.ID;
            var store = _db.Stores.Single(r => r.ID == storeID);
            store.Users.Add(newUser);
            _db.SaveChanges();

            return RedirectToAction("Index");
        }
        catch (Exception ex)
        {
            ModelState.AddModelError("", ex.InnerException.Message);

            return View();
        }
    }

我是否只是为 UserType 添加另一个“添加”调用?例如: int userTypeID = newUser.UserType.ID var usertype = _db.UserTypes.Single(s => s.ID == userTypeID)

实体框架如何知道用户有另一个父级???...我关心的?

我的直觉是我应该以不同的方式来做这件事,更具体,更准确。

4

1 回答 1

0

在这种情况下,您可能希望将用户添加到 Users 表,而不是 Stores。然后在提交之前将 StoreID 和 UserTypeID 分配给用户。

看起来你已经在你的 UI 中设置了 StoreID,你对 UserType 做同样的事情吗?如果是这样,那么只需将用户添加到用户表中就可以了。

于 2012-04-23T16:45:51.307 回答