mysql paas化_如何使用 MySQL EntityFramework 组件处理 MYSQL PaaS DB

MySQL Database on Azure 是 Azure 平台上推出的 MySQL 云数据库服务,通过全面兼容 MySQL 协议,为用户提供了一个全托管的性能稳定、可快速部署、高可用、高安全性的数据库服务。客户可以使用常见的支持 MySQL 的平台与技术进行开发与集成。本文演示了如何使用 MySQL EntityFramework 组件对 MySQL PaaS DB 进行操作。

系统环境 / 应用程序信息

ASP.NET 2005 Core / MYSQL EntityFrameWork Core

详细代码

在 VS 2015 Net Core 的环境中,安装 EntityFrameWork Core 组件,代码和测试后结果如下:

其中 Data1Context.cs 文件为:

usingMicrosoft.EntityFrameworkCore;usingMySQL.Data.EntityFrameworkCore.Extensions;namespaceConsoleApp1

{///

///The entity framework context with a data1 DbSet///

public classData1Context : DbContext

{public Data1Context(DbContextOptionsoptions)

:base(options)

{ }public DbSet Data1 { get; set; }

}///

///Factory class for EmployeesContext///

public static classData1ContextFactory

{public static Data1Context Create(stringconnectionString)

{var optionsBuilder = new DbContextOptionsBuilder();

optionsBuilder.UseMySQL(connectionString);//Ensure database creation

var context = newData1Context(optionsBuilder.Options);

context.Database.EnsureCreated();returncontext;

}

}///

///A basic class for an Employee///

public classData1

{public int Id { get; set; }public string Name1 { get; set; }

}

}

Program.cs 文件为:

usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Threading.Tasks;usingMicrosoft.Extensions.Configuration;namespaceConsoleApp1

{public classProgram

{public static void Main(string[] args)

{var builder = new ConfigurationBuilder().AddJsonFile("appsettings.json", optional: false, reloadOnChange: true);var configuration =builder.Build();string connectionString = configuration.GetConnectionString("SampleConnection");//Create an employee instance and save the entity to the database

var entry = new Data1() { Id = 3, Name1 = "XingBing"};using (var context =Data1ContextFactory.Create(connectionString))

{

context.Add(entry);

context.SaveChanges();

}

Console.WriteLine($"Data1 was saved in the database with id: {entry.Id}");

Console.ReadKey();

}

}

}

appsettings.json 文件为:

{"ConnectionStrings": {"SampleConnection": "server=XXXXXX.mysqldb.chinacloudapi.cn;userid=XXXXXX%YYYYYY;pwd=XXXXXXXXX;port=3306;database=xyudb;sslmode=none;"}

}

project.json 文件为:

{"version": "1.0.0-*","buildOptions": {"debugType": "portable","emitEntryPoint": true,"copyToOutput": {"include": "appsettings.json"}

},"dependencies": {"Microsoft.Extensions.Configuration": "1.0.0","Microsoft.Extensions.Configuration.Json": "1.0.0","Microsoft.EntityFrameworkCore": "1.0.0","MySql.Data.Core": "7.0.4-IR-191","MySql.Data.EntityFrameworkCore": "7.0.4-IR-191"},"frameworks": {"netcoreapp1.0": {"dependencies": {"Microsoft.NETCore.App": {"type": "platform","version": "1.0.0"}

},"imports": ["dnxcore50","portable-net452+win81"]

}

}

}

项目组成

solutions.jpg

运行及测试结果

console.jpg

grid.jpg

组件地址

参考方法

欢迎有兴趣的朋友多多交流

A究院研究生 Azurecommunity@qq.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值