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包管理器直接安装的。
登录数据库检查目前数据库的内容情况

OS X环境
安装DotNet Core SDK包和Visual Studio Code安装包,上面的资源里面有了,若是不知道如何配置,请看我另两篇的文章,里面做了介绍:http://www.cnblogs.com/likeli/p/5883551.html、http://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.cs、Blog.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的更多相关文章
- ASP.NET CORE 使用 EF CORE访问数据库
asp.net core通过ef core来访问数据库,这里用的是代码优先,通过迁移来同步数据库与模型. 环境:vs2017,win10,asp.net core 2.1 一.从建立asp.net c ...
- net Core 通过 Ef Core 访问、管理Mysql
net Core 通过 Ef Core 访问.管理Mysql 本文地址:http://www.cnblogs.com/likeli/p/5910524.html 环境 dotnet Core版本:1. ...
- 【ASP.NET Core】EF Core - “影子属性” 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1
[ASP.NET Core]EF Core - “影子属性” 有朋友说老周近来博客更新较慢,确实有些慢,因为有些 bug 要研究,另外就是老周把部分内容转到直播上面,所以写博客的内容减少了一点. ...
- 一个官翻教程集合:ASP.NET Core 和 EF Core 系列教程
通过一个大学课程案例讲解了复杂实体的创建过程及讲解 1.ASP.NET Core 和 Entity Framework Core 系列教程——入门 (1 / 10) 2.ASP.NET Core 和 ...
- Entity Framework Core(EF Core) 最简单的入门示例
目录 概述 基于 .NET Core 的 EF Core 入门 创建新项目 更改当前目录 安装 Entity Framework Core 创建模型 创建数据库 使用模型 基于 ASP.NET Cor ...
- .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程
本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...
- [.NET Core] - 使用 EF Core 的 Scaffold-DbContext 脚手架命令创建 DbContext
Scaffold-DbContext 命令 参数 Scaffold-DbContext [-Connection] <String> [-Provider] <String> ...
- .net core webapi+EF Core
.net core webapi+EF Core 一.描述: EF Core必须下载.net core2.0版本 Micorsoft.EntityFrameworkCore:EF框架的核心包Micor ...
- 【ASP.NET Core】EF Core 模型与数据库的创建
大家好,欢迎收看由土星卫视直播的大型综艺节目——老周吹逼逼. 今天咱们吹一下 EF Core 有关的话题.先说说模型和数据库是怎么建起来的,说装逼一点,就是我们常说的 “code first”.就是你 ...
随机推荐
- 算法笔记_013:汉诺塔问题(Java递归法和非递归法)
目录 1 问题描述 2 解决方案 2.1 递归法 2.2 非递归法 1 问题描述 Simulate the movement of the Towers of Hanoi Puzzle; Bonus ...
- 使用UIBezierPath绘制图形
当需要画图时我们一般创建一个UIView子类, 重写其中的drawRect方法 再drawRect方法中利用UIBezierPath添加画图 UIBezierPath的使用方法: (1)创建一个Bez ...
- SQLServer文件收缩-图形化+命令
汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 收缩前 图形化演示: 不仅仅可以收缩日记文件,数据库文件也是可以收缩的,只不过日记收缩比 ...
- Web Api 入门实战 (快速入门+工具使用+不依赖IIS)
平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html 屁话我也就不多说了,什么简介的也省了,直接简单概括+demo ...
- 《JavaScript设计模式与开发实践》整理
最近在研读一本书<JavaScript设计模式与开发实践>,进阶用的. 一.高阶函数 高阶函数是指至少满足下列条件之一的函数. 1. 函数可以作为参数被传递. 2. 函数可以作为返回值输出 ...
- 【NLP】揭秘马尔可夫模型神秘面纱系列文章(一)
初识马尔可夫和马尔可夫链 作者:白宁超 2016年7月10日20:34:20 摘要:最早接触马尔可夫模型的定义源于吴军先生<数学之美>一书,起初觉得深奥难懂且无什么用场.直到学习自然语言处 ...
- Lind.DDD.LindMQ~关于持久化到Redis的消息格式
回到目录 关于持久化到Redis的消息格式,主要是说在Broker上把消息持久化的过程中,需要存储哪些类型的消息,因为我们的消息是分topic的,而每个topic又有若干个queue组成,而我们的to ...
- Android中使用ViewFlipper实现屏幕页面切换(关于坐标轴的问题已补充更改)
屏幕切换指的是在同一个Activity内屏幕间的切换,ViewFlipper继承了Framelayout类,ViewAnimator类的作用是为FrameLayout里面的View切换提供动画效果.如 ...
- iOS从零开始学习直播之2.采集
直播的采集由采集的设备(摄像头.话筒)不同分为视频采集和音频采集,本篇文章会分别介绍. 1.采集步骤 1.创建捕捉会话(AVCaptureSession),iOS调用相机和话筒之前都需要创建捕 ...
- 数据库 DML、DDL、DCL区别 .
总体解释: DML(data manipulation language): 它们是SELECT.UPDATE.INSERT.DELETE,就象它的名字一样,这4条命令是用来对数据库里的数据进行操作的 ...