zoukankan      html  css  js  c++  java
  • Entity Framework简介

    零、什么是Entity Framework

    Entity Framework (简称EF),是.NET的 Object/Relational Mapping 实体框架(简称ORM),可以在 SQL Server、MySQL、Oracle、等数据库上使用。可以将数据作为业务对象和实体进行操作,使用LINQ进行查询,使用C#进行操作和检索。

    一、领域建模方式

    Entity Framework 有三种领域建模方式:Code FirstModel FirstData First

    1. Code First

      Code First 可以通过类来描述模型,然后通过类来创建数据库,这种类简称为POCO(Plain Old CLR Object)。POCO中的C是指 .NET Framework公共语言运行时(Common Language Runtime,CLR)中的一个简单对象。POCO对域对象使用尽可能简单的类,可以包含属性、方法等,但是方法不能实现持久化逻辑,也就是说POCO也可以包含业务逻辑。Code First 优点如下:

      • 可以创建一个更富有逻辑、更灵活的应用程序;
      • 因为没有自动生成难以修改的代码,所以我们可以对代码完全控制;
      • 只需要定义映射,其余一切交给Entity Framework来处理;
      • 可以用修改代码的方式来修改数据库;
      • 可以使用它来映射表结构到一个已存在的数据库。
    2. Model First

      Model First 允许我们使用实体设计器在空模型中创建模型实体,及其关系和继承层次结构,然后创建数据库。优缺点如下:

      • 无法控制实体和数据库,因为自动生成的代码难以修改,但是对于小型且简单的项目,它仍行之有效;
      • 在实体中添加额外的功能,不得不修改T4模板或者使用部分类来完成;
      • 数据库模型的更改不是最佳选择,因为是由模型定义了数据库。
    3. Data First

      Data First 使我们能够从现有数据库创建模型,减少了自动生成代码所需编写的代码量,也限制了我们使用生成代码的结构。优缺点如下:

      • 如果已有DBA设计的数据来单独开发或已存在数据库,将作为首选
      • 通过EDM向导为我们创建实体、关系和继承层次结构,修改映射后还可以生成实体;
      • 要在实体中添加额外的功能,必须通过T4修改模板或者使用部分类;
      • 数据库的手动更改变为可能,如果要修改数据库表结构,只需要从数据库更新实体模型即可。
  • 相关阅读:
    高并发量网站解决方案
    多服务器之间Session共享
    Mysql性能优化
    PHP memcache的使用教程
    select * 为什么不好? limit 1 为什么好? --mysql SQL语句优化
    八大排序对比
    /var/spool/postfix/maildrop 出现大量文件原因和解决办法
    sql根据某一个字段重复只取第一条数据
    postgreSQL 自增需要使用序列
    MySQL锁定状态查看相关命令
  • 原文地址:https://www.cnblogs.com/gangzhucoll/p/12778213.html
Copyright © 2011-2022 走看看