Entity Framework 6 Code First的简单使用和更新数据库结构

Entity Framework 6 Code First的简单使用和更新数据库结构

一、安装Entity Framework 6

      在项目中右击选择“管理NuGet程序包",联机搜索Entity Framework,点击安装

  

  

二、配置数据库连接

  在App.config中加入数据库连接字符串的配置

<connectionStrings>
    <add name="DBContext" connectionString="data source=127.0.0.1;uid=sa;pwd=123;database=test;" providerName="System.Data.SqlClient"/>
 </connectionStrings>

三、DbContext及实体类

 

    public class MyContext:DbContext
    {
        public MyContext() : base("DBContext") { }
        public DbSet<Product> Products { get; set; }
    }


    public class Product
    {
        [Key]
        public string Code { get; set; }

        public string Name { get; set; }

        public int Quantity { get; set; }
    }

 

四、简单测试

 

        static void Main(string[] args) {
            using (MyContext db = new MyContext()) {
                var product = new Product { Code = "1", Name = "p1" };
                db.Products.Add(product);
                db.SaveChanges();
            }
        }

 

五、更新数据库结构

  1.点击视图->其他窗口->程序包管理器控制台

  

  2.输入Update-Database

   这时会出现“No migrations configuration type was found in the assembly 'EF6CodeFirst'. (In Visual Studio you can use the Enable-Migrations command from Package Manager Console to add a migrations configuration).“

  3.输入Enable-Migrations

    命令执行成功后会在项目中自动添加Migrations,目录里有一个Configuration.cs,打开Configuration.cs把AutomaticMigrationsEnabled修改为true

  4.再次尝试执行Update-Database

   命令能正确执行

  5.我们尝试删除Name字段,然后执行Update-Database

     由于Name字段有数据,命令执行失败,显示如下错误:Automatic migration was not applied because it would result in data loss

     这个时候能用Update-Database -Force来强制更新数据库,但这将造成数据丢失

六、总结

  Entity Framework 6 Code First能使数据库访问和实体操作代码变得很简洁,但如果项目开发过程中需要频繁的更改数据库就要考虑清楚才使用了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值