微软跨平台ORM框架之EFCore

EFCore是微软推出的跨平台ORM框架,想较于EF6.X版本,更加轻量级。EFCore目前已经更新到2.x。

接下来用CodeFirst的方式来使用EFCore.

1.创建控制台程序

2.引入EFCore的Nuget包和Sqlserver的扩展(因为我这里用的Sqlserver数据库,若是别的数据库如Mysql引入相应的包即可)。

3.创建继承成自DbContext上下文,并重载OnConfiguring方法来构建数据库连接字符串

public class CoreDbContext : DbContext
    {
        /// <summary>
        /// 重载OnConfiguring构建数据库连接字符串
        /// </summary>
        /// <param name="optionsBuilder"></param>
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            // 这里直接写的字符串,实际项目中写在配置文件中,然后读取。这里的EFCoreDB就是生成的数据库名
            string connectionString = "server=127.0.0.1;uid=sa;pwd=sa123;database=EFCoreDB";
            optionsBuilder.UseSqlServer(connectionString);
        }

    }

4.创建Person实体类,通过EFCore映射成数据库中的表。并在上下文中注册

  public class Person
    {
        public int ID { get; set; }
        public int Age { get; set; }
        public bool Status { get; set; }
        public string Name { get; set; }
        public DateTime CreateTime { get; set; }
    }
 public class CoreDbContext : DbContext
    {
        /// <summary>
        /// 重载OnConfiguring构建数据库连接字符串
        /// </summary>
        /// <param name="optionsBuilder"></param>
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            // 这里直接写的字符串,实际项目中写在配置文件中,然后读取
            string connectionString = "server=127.0.0.1;uid=sa;pwd=sasa;database=EFCoreDB";
            optionsBuilder.UseSqlServer(connectionString);
        }
        // 注册实体
        public DbSet<Person> Person { get; set; }
    }

5.在Program文件中初始化数据库

class Program
    {
        static void Main(string[] args)
        {

            var context = new CoreDbContext();
            // 告诉EFCore我们要创建数据库
            context.Database.EnsureCreated();
            //Console.WriteLine("Hello World!");
        }
    }

6.启动程序,查看效果

数据库和Person表已生成

生成的表结构

 这里解释一下,在实体中如果有名为ID的字段,或者实体名+ID的字段如:PersonID,那么EFCore生成的表会自动标识为主键。

备注:上边用来创建的数据库的方法 context.Database.EnsureCreated(); 如果存在当前数据库则不会创建。

那么增加了实体,该如何更新数据库呢?  context.Database.EnsureDeleted(); 这个方法顾名思义是用来删除数据库。

先调用EnsureDeleted 在调用 EnsureCreated 实现更新数据库的操作。

class Program
    {
        static void Main(string[] args)
        {

            var context = new CoreDbContext();
            // 删除数据库
            context.Database.EnsureDeleted();
            // 告诉EFCore我们要创建数据库
            context.Database.EnsureCreated();
            //Console.WriteLine("Hello World!");
        }
    }

好嘞! 使用EFCore生成数据库和表就完成了。

原文地址:https://www.cnblogs.com/jixiaosa/p/10312143.html

时间: 2024-10-10 00:53:22

微软跨平台ORM框架之EFCore的相关文章

微软跨平台ORM框架之EFCore — 约定与属性映射

EFCore中的约定简单来说就是规则,CodeFirst基于模型的约定来映射表结构.除此之外还有Fluent API.Data Annotations(数据注释) 可以帮助我们进一步配置模型. 按照这三者的优先级高低排序分别是:Fluent API.Data Annotations(数据注释).约定. 1.约定 public class Person { public int ID { get; set; } public int Age { get; set; } public bool St

Mego(2) - NET主流ORM框架分析

接上文我们测试了各个ORM框架的性能,大家可以很直观的看到各个ORM框架与原生的ADO.NET在境删改查的性能差异.这里和大家分享下我对ORM框架的理解及一些使用经验. ORM框架工作原理 典型ORM框架实现 EF功能最强的ORM EF与EFCore缺陷 ORM框架工作原理 所有的ORM框架的工作原理都离不开下面这张图,只是每个框架的实现程度不同但是最终的目的是相同的. 如果是一个ORM框架那么一定会有上图中蓝色部分的这几个元素,无论是增删改查对于ORM一定是以对象为起点,使用对象构造出LINQ

基于.NET的微软ORM框架视频教程(Entity Framework技术)

基于.NET的微软ORM框架视频教程(Entity Framework技术) 第一讲  ORM映射 第二讲 初识EntifyFramework框架 第三讲 LINQ表达式查询 第四讲 LINQ方法查询 第五讲 LINQ TO Entities 第六讲 ObjectQuery查询(上) 第七讲 ObjectQuery查询(下) 第八讲 Entity中的增删改及事务处理 第九讲 Entity中的存储过程使用(完) 源代码及视频

最好的5个Android ORM框架

在开发Android应用时,保存数据有这么几个方式, 一个是本地保存,一个是放在后台(提供API接口),还有一个是放在开放云服务上(如 SyncAdapter 会是一个不错的选择). 对于第一种方式,即本地数据存储,如嵌入式SQLLite,你可以选择直接使用SQL语句.Content Provider 或 ORM(对象关系数据映射). 对于 Android 应用的开发,主要是使用Java语言,所以适用于Java语言的一些ORM,也能移植于 Android 平台上. 下面是5个可用ORM的总体介绍

自己写ORM框架 DBUtils

ORM框架想必大家都比较熟知了,即对象关系映射(英语:Object Relation Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言里使用的"虚拟对象数据库". 当你开发一个应用程序的时候(不使用O/R MAPPING),你可能会写不少数据访问层的代码,用来从数据库保存,删除,读取对象信息,等等. 现在流行的ORM框架有: JAVA系列:APACHE

.Net开源微型ORM框架测评

什么是ORM? 对象关系映射(英语:Object Relation Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”. 一般的ORM包括以下四部分: 一个对持久类对象进行CRUD操作的API: 一个语言或API用来规定与类和类属性相关的查询: 一个规定MAPPING METADATA的工具: 一种技术可以让ORM的实现同事务对象一起进行D

.NET 跨平台界面框架和为什么你首先要考虑再三

???原文地址 现在用 C# 来开发?跨平台应用已经有很成熟的方案,即共用非界面代码,而每个操作系统搭配特定的用户界面代码.这个方案的好处是可以直接使用操作系统原生的控件和第三方控件,还能够和操作系统深度集成. 这里的深度集成主要是指一些 Windows 专有的系统特性: Windows 托盘 Windows 跳转列表 Windows 系统主题 也包括一些移动平台的特性,例如 iOS 的原生滑动. ?由于操作系统上其他程序一般都使用原生控件,于是只有当你的程序采用同样技术时,它才能很好地保持一致

最受欢迎的5个Android ORM框架

在开发Android应用时,保存数据有这么几个方式, 一个是本地保存,一个是放在后台(提供API接口),还有一个是放在开放云服务上(如 SyncAdapter 会是一个不错的选择). 对于第一种方式,即本地数据存储,如嵌入式SQLite,你可以选择直接使用SQL语句.Content Provider 或 ORM(对象关系数据映射). 对于 Android 应用的开发,主要是使用Java语言,所以适用于Java语言的一些ORM,也能移植于 Android 平台上. 下面是5个可用ORM的总体介绍:

Net框架下-ORM框架LLBLGen的简介

>对于应用程序行业领域来说,涉及到Net框架的,在众多支持大型项目的商用ORM框架中,使用最多的目前了解的主要有三款: 1.NHibernate(从Java版移植来的Net版). 2.微软的EF. 3.还有就是今天提到的LLBLGen >ORM之间的性能比较 从上图的测试结果可以看出,传统的手动编写代码访问数据库,例如手动编写的ADO.NET,仍然是从数据库中取值的最快捷的方式,性能依然最好.而相比于三大ORM框架来说由于NH的功能庞大EF的次之,LLBLGen相较于来说性能最好.当然对比OR