本文地址: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包管理器直接安装的。

登录数据库检查目前数据库的内容情况

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

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

导入Mysql驱动包

打开游览器,去NuGet逛逛,搜索mysql官方出的驱动包 MySql.Data.EntityFrameworkCore

可以看到上面的库名 MySql.Data.EntityFrameworkCore, 还有版本号 7.0.5-IR21

打开项目中的project.json,在该文件中加入mysql驱动包的名字,还有版本号。

然后在终端中键入命令,通过Nuget回复所有的依赖包:

dotbet restore

增加实体和上下文

在项目的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'运行。

查看一下数据库里面的变化:

可以看到MySQL数据里面多出了一个名叫Ef的库

表结构也已经建立,User表中已经添加了新数据。

现在加上Blog的数据,这里表现外键关系。

发现外键关系也有了。

总结 目前看来,Ef Core 的使用方法和Windows上的EF差别并不大,但是目前只是早期版本,版本应该还会快速迭代,用于生产环节,那就得请三思了。

本文是在Mac上做了了Ef Core的操作演示,我也在Windows上测试过了,编写方法和方式都是一样的。各位类推一下就可以了。

Asp.net Core 通过 Ef Core 访问、管理Mysql的更多相关文章

  1. ASP.NET CORE 使用 EF CORE访问数据库

    asp.net core通过ef core来访问数据库,这里用的是代码优先,通过迁移来同步数据库与模型. 环境:vs2017,win10,asp.net core 2.1 一.从建立asp.net c ...

  2. net Core 通过 Ef Core 访问、管理Mysql

    net Core 通过 Ef Core 访问.管理Mysql 本文地址:http://www.cnblogs.com/likeli/p/5910524.html 环境 dotnet Core版本:1. ...

  3. 【ASP.NET Core】EF Core - “影子属性” 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1

    [ASP.NET Core]EF Core - “影子属性”   有朋友说老周近来博客更新较慢,确实有些慢,因为有些 bug 要研究,另外就是老周把部分内容转到直播上面,所以写博客的内容减少了一点. ...

  4. 一个官翻教程集合:ASP.NET Core 和 EF Core 系列教程

    通过一个大学课程案例讲解了复杂实体的创建过程及讲解 1.ASP.NET Core 和 Entity Framework Core 系列教程——入门 (1 / 10) 2.ASP.NET Core 和 ...

  5. Entity Framework Core(EF Core) 最简单的入门示例

    目录 概述 基于 .NET Core 的 EF Core 入门 创建新项目 更改当前目录 安装 Entity Framework Core 创建模型 创建数据库 使用模型 基于 ASP.NET Cor ...

  6. .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程

    本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...

  7. [.NET Core] - 使用 EF Core 的 Scaffold-DbContext 脚手架命令创建 DbContext

    Scaffold-DbContext 命令 参数 Scaffold-DbContext [-Connection] <String> [-Provider] <String> ...

  8. .net core webapi+EF Core

    .net core webapi+EF Core 一.描述: EF Core必须下载.net core2.0版本 Micorsoft.EntityFrameworkCore:EF框架的核心包Micor ...

  9. 【ASP.NET Core】EF Core 模型与数据库的创建

    大家好,欢迎收看由土星卫视直播的大型综艺节目——老周吹逼逼. 今天咱们吹一下 EF Core 有关的话题.先说说模型和数据库是怎么建起来的,说装逼一点,就是我们常说的 “code first”.就是你 ...

随机推荐

  1. Bootstrap-Select 动态加载数据的小记

    关于前端框架系列的可以参考我我刚学Bootstrap时候写的LoT.UI http://www.cnblogs.com/dunitian/p/4822808.html#lotui bootstrap- ...

  2. JavaScript Math和Number对象

    目录 1. Math 对象:数学对象,提供对数据的数学计算.如:获取绝对值.向上取整等.无构造函数,无法被初始化,只提供静态属性和方法. 2. Number 对象 :Js中提供数字的对象.包含整数.浮 ...

  3. QT5利用chromium内核与HTML页面交互

    在QT5.4之前,做QT开发浏览器只能选择QWebkit,但是有过使用的都会发现,这个webkit不是出奇的慢,简直是慢的令人发指,Release模式下还行,debug下你就无语了,但是webkit毕 ...

  4. vue.js初探

    前言 入手2016最火前端框架之一vue.js.大概从网上找了些资料看了下vue.js,从网上的资料来看只能惊叹其发展速度太快,让我意外的是其作者是华人的前提下作品这么受欢迎. 网上的博客和教程各种组 ...

  5. OpenLiveWriter代码插件

    1.OpenLiveWriter安装 Windows Live Writer在2012年就停止了更新,Open Live Writer(以下简称OLW)是由Windows Live WriterWri ...

  6. C# BackgroundWorker 详解

    在C#程序中,经常会有一些耗时较长的CPU密集型运算,如果直接在 UI 线程执行这样的运算就会出现UI不响应的问题.解决这类问题的主要途径是使用多线程,启动一个后台线程,把运算操作放在这个后台线程中完 ...

  7. 微软发布VSBT,无需安装Visual Studio即可实现项目编译

    安装了Visual Studio的那些使用微软平台的开发者通常能够非常容易地操作自己的项目:打开解决方案,修改内容,设置好所有必须的文件以及配置后编译项目.但是在构建服务器或者持续交付系统等没有安装V ...

  8. 【JQ基础】DOM操作

    内部插入:append() //向每个匹配的元素内部追加内容,可包含 HTML 标签 $(selector).append(function(index,html)) /*•index - 可选.接收 ...

  9. Hello Jexus

    一.关于 CentOS CentOS(Community Enterprise Operating System)是Linux发行版之一,它是来自于Red Hat Enterprise Linux依照 ...

  10. Mono 3.8发布:性能进一步改进,可伸缩性提升

    9月4日,Mono 3.8.0发布了.该版本的运行时带来了一些性能和可伸缩性方面的改进,同时完成了向Windows平台的移植. Mono遵循Gnome和Linux内核的版本编号策略,这意味着3.8是3 ...