星空网 > 软件开发 > ASP.net

初学EF CodeFirst遇到的创建表的问题

  最近开始学EF CodeFirst,在学习的初期我就遇到了一个问题,创建一张表的时候总是报错误。

  Message:An error occurred while updating the entries. See the inner exception for details.

  InnerException: "对象名 'dbo.XXXX' 无效。"

  我根据网上的各种方案来解决。。。。。。然并卵!然后在博问提问。。。。。。本想找个老司机带带路的(估计问题描述的不给力!),然并卵!伤心!

  好了,先简单说下我的这个小白问题,很简单的一个问题,在第一天的学习中,我在Sql Server中新建了两张表,两张表的Model如下:

public class Destination  {    public int DestinationId { get; set; }    public string Name { get; set; }    public string Country { get; set; }    public string Description { get; set; }    public byte[] Photo { get; set; }    public List<Lodging> Lodgings { get; set; }  }public class Lodging  {    public int LodgingId { get; set; }    public string Name { get; set; }    public string Owner { get; set; }    public bool IsResort { get; set; }    public Destination Destination { get; set; }  }

再加上一些其他的小知识点,当天的学习就结束了,然后第二天我在继续学习的时候我新建一张新表的时候,确总是报错,说对象不存在,如下:

public class Person  {    public int SocialSecurityNumber { get; set; }    public string FirstName { get; set; }    public string LastName { get; set; }    public byte[] RowVersion { get; set; }  }static void Main(string[] args)    {      try      {        InserPerson();      }      catch (Exception ex)      {        var ss = ex.Message;      }      Console.ReadKey();    }    static void InserPerson()    {      var model = new Person      {        FirstName = "Rowan",        LastName = "Miller",        SocialSecurityNumber = 12345678      };      using (var context = new BreakAwayContext())      {        context.People.Add(model);        context.SaveChanges();      }    }

我想看到这儿的应该知道我哪里错了!但是我当时一脸懵逼的,我各种求帮助都没有解决,就在我快放弃的时候,我突然想起,在我第一天学习的时候有个对象DropCreateDatabaseIfModelChanges,这个对象的作用就跟他的英文直译的意思一个样,就是如果你先创建了一张表,但是后来你要修改约束,就需要用这个了。这个对象继承的是IDatabaseInitializer这个接口,得,我就搜索了这个接口,然后再MSDN中找到了它。。。

地址:https://msdn.microsoft.com/en-us/library/gg696323(v=vs.113).aspx

然后不负我的期望,我找到我想要的,继承这个接口的有三个,分别是DropCreateDatabaseIfModelChanges,DropCreateDatabaseAlways, CreateDatabaseIfNotExists

大家看名字也就知道他的用途了(这里不得不说的是好的命名的确比详细的注释更给力),当然也可以搜索一下,介绍这三个对象的也有很对博客文章。

 

  但是我想说的是,然并卵啊。。。。。。最后我才醒悟,正常情况下,我们是创建好我们需要的Model后才或才是创建表,如果后期需求的增加或者变更,我们只有先在数据库中增加表,然后再在代码中增加Model,和进行相关的配置,不能通过代码再去增加表。

  好了,就记这些,有错,请留个言,谢谢!




原标题:初学EF CodeFirst遇到的创建表的问题

关键词:

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

海运运输:https://www.goluckyvip.com/tag/89971.html
国际海运物流运输:https://www.goluckyvip.com/tag/89972.html
国内海运:https://www.goluckyvip.com/tag/89973.html
海运国内:https://www.goluckyvip.com/tag/89974.html
国内海运运输:https://www.goluckyvip.com/tag/89975.html
海运到马来西亚海运:https://www.goluckyvip.com/tag/89977.html
探讨内地人开设香港账户的可行性 :https://www.kjdsnews.com/a/1836442.html
在古巴做游轮 古巴旅游项目:https://www.vstour.cn/a/363194.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流