zoukankan      html  css  js  c++  java
  • 初识EntityFramework6

    参考:https://www.cnblogs.com/wujingtao/p/5401132.html

    什么是EF?

    EF是一种ORM(Object-relational mapping)框架,它能把我们在编程时使用对象映射到底层的数据库结构。比如,你可以在数据库中建立一个Order表,让它与程序中的Order类建立映射关系,这样一来,程序中的每个Order对象都对应着Order表中的一条记录,ORM框架负责把从数据库传回的记录集转换为对象,也可以依据对象当前所处的具体状态生成相应的SQL命令发给数据库,完成数据的存取工作(常见的数据存取操作可简称为CRUD:Create、Read、Update、Delete)。

    EF的三种开发方式

    EF支持三种开发模式: Code First、Database First和Model First。

    方式一:Code First

    对于初次接触的人,EF的Code First实在很有点魔幻色彩。下面就让我们来体会一下。 创建两个类:Book(书)和BookReview(书评)。一本书可以有多条书评,因此,它们是一对多的关系:

    1. public class Book
    2. {
    3. public virtual int Id {get; set;}
    4. public virtual string Name { get; set; }
    5. public virtual List<BookReview> Reviews { get; set; }
    6. }
    7. public class BookReview
    8. {
    9. public int Id{get; set;}
    10. public int BookId { get; set; }
    11. public virtual string Content { get; set; }
    12. public virtual Book AssoicationWithBook { get; set; }
    13. }

    好了,现在创建一个派生自DbContext的子类:

    1. public class BookDb : DbContext
    2. {
    3. public DbSet<Book> Books { get; set; }
    4. public DbSet<BookReview> Reviews { get; set; }
    5. }

    现在可以在程序中随意写几行代码从数据库中提取数据:

    1. static void Main(string[] args)
    2. {
    3. using (var context = new BookDb())
    4. {
    5. Console.WriteLine("数据库中有{0}本书",context.Books.Count());
    6. }
    7. }

    运行一下,如果计算机上安装有SqlExpress,那么或者是在应用程序文件夹,或者是打开SQL Server Management Studio(SSME)查看本机SQLServer,你就会发现,数据库己经创建好,其中的表及表的关联也帮助你完成了:

    运行结果

    貌似我什么也没干,一切就OK了!

    方式二:Database First

    这是EF从1.0开始就支持的特性,其思路是:先设计并建好数据库,然后使用Visual Studio的向导创建EF数据模型并生成实体类代码。 这是最成熟稳定的方式,其设计器相当地完善,基本上能满足实际开发中的各种需求。 我个人认为这是开发正式项目最合适的方式。

    方式三:Model First

    这种模式是先在可视化设计器中创建实体和它们间的关联,然后设计器生成SQL命令并保存于一个SQL文件中,通过执行这一SQL文件完成数据库的创建和修改工作。

    模型设计器

    PS:这种方式在EF7中好像以被取消,所以也不推荐再使用了。

    上面部分内容摘录自bitfan的专栏

    Entity Framework走马观花之把握全局

    比较CodeFirst和Database First

    通过Code First构建数据库虽然方便,不过EF帮我们生成的数据表结构真的很一般。在上面的例子中,在Code First生成的表内Name、Content、BookId都是可以为空的,也就是说没有为它们建立约束。可要是使用Code First来建立约束就有点麻烦了,所以我们一般都不是通过代码来生成数据库,而是通过数据库来反向生成代码(Database First)。

    这一节只是做个介绍,下一节我将演示一下如何使用EF连接数据库,特别是MySQL数据库。EF通过向导连接SQL Server基本上都是下一步,可连MySQL还需要些配置。

  • 相关阅读:
    oracle 对应的JDBC驱动 版本
    Java Web中如何访问WEB-INF下的XML文件
    网站制作越简单越好(一):css样式命名规范
    HTTPClient以WebAPI方式发送formData数据上传文件
    NetCore(依赖注入)
    JS a标签 onClick问题
    NetCore的配置管理(1)
    Centos 系统安装NetCore SDK命令以及一系列操作(3)
    Centos 系统安装NetCore SDK命令以及一系列操作(2)
    Centos 系统安装NetCore SDK命令以及一系列操作(1)
  • 原文地址:https://www.cnblogs.com/bruce1992/p/15489718.html
Copyright © 2011-2022 走看看