繁体   English   中英

ASP.NET C#实体框架-如何正确更新外键? - 第2部分

[英]ASP.NET C# Entity Framework - How to update Foreign Key properly? - Part 2

这个问题就像我上一个问题的第2部分

这是我学到的并希望成为现实的事情:

  1. 不要将数据实体上下文用作静态
  2. 在使用后处理数据上下文-通常在一段时间后-
  3. 将参数传递给UPDATING Entity方法而不是Entity(我将在这里解释,在这里我处于十字路口)

这是我修改的代码:

public class ManagerBase
    {
        private NoxonEntities _entities = null;

        public NoxonEntities Entities
        {
            get
            {
                if (_entities == null)
                    _entities = new NoxonEntities();

                return _entities;
            }
        }
    }

//Managers uses ManagerBase class as a Base class
MemberManager currentMemberManager = new MemberManager();
currentMemberManager.Save(memberId, username, password, languageId);


//MemberManager class
public Member Save(long memId, string username, string password, int langId)
        {
            using (var Context =   base.Entities)
            {
                var Data = Context.Member.First(c => c.Id == memId);

                Data.Username = username;
                Data.Password = password;
                Data.Language = Context.Language.First(c => c.Id == langId); //Gets the foreign entity

                Context.SaveChanges();

                return Data;
            }
        }

这毫无例外地起作用。 但通常,此SAVE方法是通过接口实现的方法。 所以,我宁愿一个对象值传递给save方法不是将所有的领域,如上述。 例如,我想使用这个:

//Member is an EntityFramework Object which was created during EF Model when I added by visual studio
//Filter is the method that returns an EntityFramework Object from EF (and eventually database) with given some arguments
//SomeArguments could be  MemberId = 2
Member modifiedMember = currentMemberManager.Filter(someArguments);
modifiedMember.UserName = "newvalue";
currentMemberManager.Save(modifiedMember);

在SAVE方法中,也许我可以这样使用:

public Member Save(Member modifiedMember)
            {
                using (var Context =   base.Entities)
                {
                    var Data = Context.Member.First(c => c.Id == modifiedMember.Id);

                    Data.Username = modifiedMember.Username;
                    Data.Password = modifiedMember.Password;
                    Data.Language = Context.Language.First(c => c.Id == modifiedMember.LanguageId); //Gets the foreign entity

                    Context.SaveChanges();

                    return Data;
                }
            }

如果我要像上面的右一个那样使用它,我想我不应该使用传递对象EF Object,而是应该使用我将要编写的其他一些类来将参数映射到EF Member Entity。

第一个问题:这是一个好方法吗?

public class MyMember
{
    public long Id { set; get; }
    public string Username { set; get; }
    public string Password { set; get; }
    public int LanguageId { set; get; }
}

MyMember.Username = "NewValue";
MyMember.LanguageId = 4; //4 as in new value
currentMemberManager.Save(MyMember); //As you can see MyMember is not an EF Entity in here

但这将花费很长时间,因为已经有一些书面代码。

第二个问题:我不能境外使用的EF实体对象,然后修改它那里将其保存 MemberManager类?

再次感谢您的提前帮助。

答案是:

如何更新实体?

我感谢您为我提供帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM