varbuilder = newDbContextOptionsBuilder()
.UseSqlServer(configuration.GetConnectionString( "Default"));
returnnewTGDbContext(builder.Options);
}
改成
publicTGDbContext CreateDbContext(string[] args)
{
varconfiguration = BuildConfiguration();
varbuilder = newDbContextOptionsBuilder()
.UseMySQL(configuration.GetConnectionString( "Default"));
returnnewTGDbContext(builder.Options);
}
原本以为这样就能ok的,update-database的时候一堆错误,去issue上看了下,都有这个问题,有人建议用Pomele的MySql驱动,还提了PR,当我今天(3月9号)去看的时候PR已经通过,但Nuget包还未更新。
自给自足丰衣足食,自己来吧,其实非常简单
先去掉刚引入的Volo.Abp.EntityFrameworkCore.MySql,然后引入Pomelo.EntityFrameworkCore.MySql,随后上述代码改为:
publicTGDbContext CreateDbContext(string[] args)
{
varconfiguration = BuildConfiguration();
varbuilder = newDbContextOptionsBuilder()
.UseMySql(configuration.GetConnectionString( "Default"));
returnnewTGDbContext(builder.Options);
}
ok,简单改造完成,我们再来update-database,我们的创建顺利的完成了。
你以为结束了吗,幼稚!默认启动的时候他还是会选择Sql Server,我们看下代码,在Web项目下的xxWebModule.cs,xx是你的项目名,这个是我们web的Module文件,我们知道Abp是一个Module加载的框架。在这个项目中同样引入Pomelo.EntityFrameworkCore.MySql,随后修改ConfigureDatabaseServices方法,
private voidConfigureDatabaseServices()
{
Configure(options =>
{
options .Configure( context=>
{
if( context.ExistingConnection!= null)
{
context.DbContextOptions.UseMySql( context.ExistingConnection);
}
else
{
context.DbContextOptions.UseMySql( context.ConnectionString);
}
});
});
}
改完以上的代码,你就可以顺利启动Abp vNext for MySql了。
改的不是很优雅,毕竟下一个版本应该会解决这个问题。之前用Abp Core做了小程序并放到了生产环境,启动慢了点,但是运行什么都比较稳定,开发也比较便捷,看了Abp vNext后,感觉一种小清新,相信在不久之后,我会使用它放到生产环境。其实一些老鸟的话,自己都有自己的框架,说实在的,Abp的好处就在于能够让大家有一种统一的快速的开发方式。