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能使数据库访问和实体操作代码变得很简洁,但如果项目开发过程中需要频繁的更改数据库就要考虑清楚才使用了。

posted @   congflag  阅读(746)  评论(0)    收藏  举报
编辑推荐:
· C#高性能开发之类型系统:从 C# 7.0 到 C# 14 的类型系统演进全景
· 从零实现富文本编辑器#3-基于Delta的线性数据结构模型
· 记一次 .NET某旅行社酒店管理系统 卡死分析
· 长文讲解 MCP 和案例实战
· Hangfire Redis 实现秒级定时任务,使用 CQRS 实现动态执行代码
阅读排行:
· 使用TypeScript开发微信小程序(云开发)-入门篇
· 没几个人需要了解的JDK知识,我却花了3天时间研究
· C#高性能开发之类型系统:从 C# 7.0 到 C# 14 的类型系统演进全景
· 管理100个小程序-很难吗
· 在SqlSugar的开发框架中增加对低代码EAV模型(实体-属性-值)的WebAPI实现支持
点击右上角即可分享
微信分享提示