zoukankan      html  css  js  c++  java
  • ORM系列之二:EF(2)Code First

    目录

    1. Code First是什么?

    2. Code First 简单示例

    3. 数据存储

    4. 迁移

    Code First是什么

      Code First 顾名思义就是先写代码,当然不是乱写,而是按照一定的约定,先创建实体类,再通过编辑器自动生成数据模型。Code FirstEF的三大模式之一,主要使用新的系统开发,对应数据库已存在的情况下不适合。 

    Code First 简单示例  

      下面通过一个简单的示例,让我们来熟悉一下Code First模式。 

      第一步:创建一个控制台程序,命名为EF.CodeFirstSample”。

      

      第二步:打开NuGet包管理界面,为上面新建的控制台程序安装EF

       

      安装成功之后,我们就可以在引用下面看到EF组件,如下图:

       

      第三步:创建模型

       该示例中我们使用非常简单的模型,直接Program.cs文件中进行定义。

       Program.cs中添加以下两个类:   

    public class Blog
        {
            public int BlogId { get; set; }
            public string Name { get; set; }
    
            public virtual List<Post> Posts { get; set; }
        }
    
        public class Post
        {
            public int PostId { get; set; }
            public string Title { get; set; }
            public string Content { get; set; }
    
            public int BlogId { get; set; }
            public virtual Blog Blog { get; set; }
        }
    View Code

       第四步:创建上下文

      创建一个上下文,用于和数据库保持会话,以便我们查询和保存数据。我们定义一个派生自System.Data.Entity.DbContext的上下文,并为模型中每个类公开一个类型化DbSet<TEntity> 

     public class BloggingContext : DbContext
        {
            public DbSet<Blog> Blogs { get; set; }
            public DbSet<Post> Posts { get; set; }
        }
    View Code

      第五步:读写数据

      实现program.cs中的Main方法,如下所示,这些代码为上下文创建一个新的实例,然后使用该实例为Blog表插入一条记录,然后在从数据库读取所有的Blog,并且把名称显示出来,具体代码如下: 

     static void Main(string[] args)
            {
                using (var db = new BloggingContext())
                {
                    Blog blog = new Blog() { Name = "this is a test Name!" };
                    db.Blogs.Add(blog);
                    db.SaveChanges();
    
                    foreach (var item in db.Blogs)
                    {
                        Console.WriteLine("Name:"+item.Name);
                    }               
                }
    
                Console.Read();
            }
    View Code

       

      运行结果

      

      运行结果显示,我们已经成功添加一条数据,并且成功读取显示出来,那我们的数据存储在哪里呢?

      数据在哪里

      如果本地Sql EXPRESS实例可用(默认情况下随vs2010安装)的话, 则Code First默认对该实例创建数据库;

      如果Sql EXPRESS实例不可用,则Code First将尝试使用LocalDb(默认情况下随vs2012安装);

      如果Sql EXPRESS和LocalDb同时存在,则Code First会优先使用Sql EXPRESS;

      如果两个都不存在,则运行就报错,所以需要自己在配置文件设置数据库连接字符串。

      由于我们只有LocalDb可用,所以运行之后在LocalDb中自定创建一个新的数据库和物理表,如下:

      

         

          数据迁移

      在实际开发中经常会设计表之后再修改表结构,那么对于Code First中修改表又是如何实现的呢?例如,现在为Blog类增加一个Url属性,如下:

       

          再运行程序,会发现如下提示:

      

       提示信息非常明确,这个时候通过迁移来更新数据库。  

      第一步:打开NuGet控制台,输入"Enable-Migrations"启用Code First迁移。

      

      第二步:在控制台中输入“Add-Migration AddUrl”,其中AddUrl是迁移的名称,方便以后根据这个名称进行降级。

      

      第三步:在控制台中输入“Update-Database”,这个时候可能会因为当前项目不是启动项而报错,我们可以执行Update-Database的时候指定启动,这么我只是简单的将当前项目设置为启动项。

      

      至此,迁移工作完成,此时我们查看数据库会发现,Blog表中已经增加了URL字段,见下图:

      

  • 相关阅读:
    JDK1.8中对hashmap的优化
    ShutdownHook作用
    【工作相关】常用Shell命令
    [技术学习]收藏技术博客
    【技术学习】Mongo Administration
    【技术学习】saltstack 笔记(一) --匹配Minion
    【工作相关】个人常用脚本及代码
    【工作相关】常用工具
    【现场问题】add trust cert into JAVA_HOME
    【工作相关】替换Rancher证书
  • 原文地址:https://www.cnblogs.com/qianxingdewoniu/p/6114859.html
Copyright © 2011-2022 走看看