.NET Core Entity Framework Part 1

Entity Framework 是一个方便的数据库基架,比方说你在项目某个文件夹下创建了一个如下所示的Person类

    public class Person
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Job { get; set; }
        public int Age { get; set; }
    }

然后动再做小小的配置, 框架就可以自动帮你创建一个数据库,并且自动添加一张为Person的表,各字段与Person属性一一对应。此框架支持MySql、SqlServer、oracle等。。。

此篇讲述简单的EF内存模拟数据库测试,第二篇讲述使用真实的数据库。

创建项目

  • 打开 Visual Studio 2017
  • “文件”>“新建”>“项目...”
  • 从左侧菜单中选择“已安装”>“Visual C#”->“Windows Desktop”
  • 选择“控制台应用(.NET Framework)”项目模板
  • 确保项目面向 .NET Framework 4.6.1 或更高版本
  • 将项目命名为 ConsoleApp.NewDb,并单击“确定”

安装 Entity Framework

点击菜单栏“工具”>“NuGet 包管理器”>“包管理器控制台”
运行 Install-Package Microsoft.EntityFrameworkCore.InMemory
在本教程的后面部分,你会使用某些 Entity Framework Tools 维护数据库。 因此,请同时安装该工具包。
运行 Install-Package Microsoft.EntityFrameworkCore.Tools

创建模型

现在是时候定义构成模型的上下文和实体类了。
在项目中创建一个Database文件夹,然后在Database文件夹,在Database文件夹下创建一个Table文件夹并添加Person.cs替换代码如下所示:

namespace ConsoleApp.NewDb.Database.Table
{
    public class Person
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Job { get; set; }
        public int Age { get; set; }
    }
}

创建数据库上下文

在Database文件夹下创建DBContext.cs文件如下所示;

using ConsoleApp.NewDb.Database.Table;
using Microsoft.EntityFrameworkCore;
namespace ConsoleApp.NewDb.Database
{
    class DBContext : DbContext
    {
        public DbSet<Person> Person { get; set; }
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseInMemoryDatabase("PersonList");
        }
    }
}

其中optionsBuilder.UseInMemoryDatabase("PersonList");意味着在内存中模拟一个数据库。在下一篇博客我们再讲述使用真实的数据库。

读写数据库数据

现在可以使用模型执行数据访问。
打开 Program.cs
将此文件的内容替换为以下代码

using ConsoleApp.NewDb.Database;
using ConsoleApp.NewDb.Database.Table;
using System;

namespace ConsoleApp.NewDb
{
    class Program
    {
        static void Main(string[] args)
        {
            // Which mean, Get context of the database.
            DBContext context = new DBContext();
            
            // Initialize table records of the database.
            context.Person.AddRange(
                new Person { Name = "猪猪", Job = "程序员", Age = 20 },
                new Person { Name = "妞妞", Job = "程序媛", Age = 22 },
                new Person { Name = "板凳", Job = "程序猿", Age = 44 }
                );

            // Update the database records.
            context.SaveChanges();

            // Remove at 3 of the id.
            Person oldPerson = context.Person.Find(3);
            context.Person.Remove(oldPerson);
            context.SaveChanges();

            // Insert a new data of the Person
            context.Person.Add(new Person { Name = "蛋蛋", Job = "项目经理", Age = 35 });
            context.SaveChanges();

            foreach (Person p in context.Person)
            {
                Console.WriteLine();
                Console.WriteLine($"Name:{p.Name}\nJob:{p.Job}\nAge:{p.Age}");
            }

            Console.WriteLine("Press any key to continue...");
            Console.ReadKey();
        }
    }
}
  1. 其中DBContext context = ..意思是得到一个数据库上下文或者说是把柄。

  2. context.Person.AddRange(...)意味着初始化一些数据。以便于后面进行读写操作。

  3. 因为我们第2点做了初始化操作,所以我们必须要调用一下context.SaveChanges()更新一下数据库里的数据。因为框架先把我们做新增的数据放到了储存区。直到你调用了context.SaveChanges()才会从储存区添加到数据库。

  4. Person oldPerson = context.Person.Find(3)意思是从context.Person集合 或(数据库)中搜索id为3的Person。此id就是你创建的Person.cs类里面的那个id属性。找到之后返回给oldPerson对象,再调用context.Person.Remove(oldPerson)从数据库中移除此Person。调用context.SaveChanges()保存更改。

5.context.Person.Add(..)向储存区插入一条新的Person然后调用contetx.SaveChanges()更新数据。

6.foreach(var ... in ...) 遍历context.Person集合数据,结果如下:

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容