Asp.net Core 通過 Ef Core 訪問、管理Mysql


本文地址:http://www.cnblogs.com/likeli/p/5910524.html

環境

dotnet Core版本:1.0.0-preview2-003131

本文分為Window環境和Mac Os X環境。


相關資源下載

Visual Studio Code:https://code.visualstudio.com

DotNet Core:https://dotnet.github.io/

MySql.Data.EntityFrameworkCore:http://www.nuget.org/packages/MySql.Data.EntityFrameworkCore/7.0.5-IR21

Entity Framework Core(Pomelo):https://docs.efproject.net/en/latest/providers/pomelo/index.html#supported-database-engines

Entity Framework Core(Official):https://docs.efproject.net/en/latest/providers/mysql/

MySql數據庫

安裝配置就不介紹了,不是本文重點,本文中,Mac下用的Mysql是通過brew包管理器直接安裝的。

登錄數據庫檢查目前數據庫的內容情況

mysqlEfCore icon

OS X環境

安裝DotNet Core SDK包和Visual Studio Code安裝包,上面的資源里面有了,若是不知道如何配置,請看我另兩篇的文章,里面做了介紹:http://www.cnblogs.com/likeli/p/5883551.htmlhttp://www.cnblogs.com/likeli/p/5910475.html

創建Web項目

在准備的項目目錄下執行命令,進行創建:

dotnet new -t web

mysqlEfCore icon

Visual Studio Code 打開,安裝好了C#插件后,可以着色、提示等。

導入Mysql驅動包

打開游覽器,去NuGet逛逛,搜索mysql官方出的驅動包 MySql.Data.EntityFrameworkCore

mysqlEfCore icon

可以看到上面的庫名 MySql.Data.EntityFrameworkCore, 還有版本號 7.0.5-IR21

打開項目中的project.json,在該文件中加入mysql驅動包的名字,還有版本號。

mysqlEfCore icon

然后在終端中鍵入命令,通過Nuget回復所有的依賴包:

dotbet restore

mysqlEfCore icon

增加實體和上下文

在項目的Models文件夾下創建新的.cs文件,加入User.csBlog.cs

代碼如下:

User.cs

namespace WebApplication.Models
{
    public class User
    {
        public int UserId { set; get; }
        public string Name{set;get;}
    }
}

Blog.cs

namespace WebApplication.Models{
    public class Blog{
        public int Id{set;get;}
        public string Title{set;get;}
        public string Content{set;get;}
        
        public int UserId{set;get;}
        public virtual User User{set;get;}
    }
}

在Data文件夾下添加上下文:

DataContext.cs

using Microsoft.EntityFrameworkCore;
using MySQL.Data.EntityFrameworkCore.Extensions;
using WebApplication.Models;

namespace WebApplication.Data{
    public class DataContext : DbContext{
        public DbSet<User> Users{set;get;}

        public DbSet<Blog> Blogs{set;get;}

        protected override void OnConfiguring( DbContextOptionsBuilder optionsBuilder)
            => optionsBuilder.UseMySQL(@"Server=localhost;database=ef;uid=root;pwd=root");
    }
}

有過Ef使用經驗的開發者應該很容易懂這個過程了,其實需要說明一下的就是在非Visual Studio中開發,不能直接使用NuGet的命令的時候,就直接在project.json里面添加需要引用的包,然后執行dotnet restore還原包就可以了。

然后在Home控制器里面寫調用代碼:

using(var context = new DataContext()){
       context.Database.EnsureCreated();
       var user = new User {Name="憤怒的TryCatch"};
       context.Add(user);
   
       context.SaveChanges();
}

編譯測試

在終端鍵入 dotnet build 命令進行編譯,然后'dotnet run'運行。

mysqlEfCore icon

mysqlEfCore icon

查看一下數據庫里面的變化:

mysqlEfCore icon

可以看到MySQL數據里面多出了一個名叫Ef的庫

mysqlEfCore icon

表結構也已經建立,User表中已經添加了新數據。

現在加上Blog的數據,這里表現外鍵關系。

mysqlEfCore icon

mysqlEfCore icon

發現外鍵關系也有了。

總結 目前看來,Ef Core 的使用方法和Windows上的EF差別並不大,但是目前只是早期版本,版本應該還會快速迭代,用於生產環節,那就得請三思了。
本文是在Mac上做了了Ef Core的操作演示,我也在Windows上測試過了,編寫方法和方式都是一樣的。各位類推一下就可以了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM