从.NET Core 1.x更新到2.x后无法运行MySQL数据库迁移,未知数据库''

时间:2018-07-23 03:56:37

标签: mysql .net asp.net-core .net-core asp.net-core-2.0

我最近尝试使用MySQL将可运行的.NET Core 1.0项目更新为.NET Core 2.0。我按照Microsoft文档中的说明进行了编译和运行,但是我完全无法执行数据库迁移。每当我尝试从Package Manager控制台运行Update-Database时,都会出现错误消息:

One or more errors occurred. (Authentication to host 'localhost' for user 'user' using method 'mysql_native_password' failed with message: Unknown database '')

我的问题是,即使用户名和连接都是从连接字符串中正确获取的,但数据库名称却不是。我什至使用与连接字符串相同的信息从Server Explorer窗口连接到数据库。然后我检查了正确的appsettings(开发)文件是否在使用中。

  "ConnectionStrings": {
    "DefaultConnection": "server=localhost;database=asm;userid=user;password=password;connectionreset=true;Allow User Variables=True"
  },

我用错误信息搜索了Google,但只找到了数据库名称有拼写错误或明显不存在的帖子和评论,但事实并非如此。数据库用户具有在MySQL Workbench中设置的所有管理角色和特权。 我们将不胜感激任何帮助或指针(甚至包括如何调试Update-Database进程以检查何时创建/设置DbContext)。

添加的信息:

Startup.cs(已删除,以省略一些使用和大多数服务。AddScoped<>())

using asm.Data;
using asm.Enumeration;
using asm.Models;
using asm.Services;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
using Microsoft.AspNetCore.Localization;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using Microsoft.AspNetCore.DataProtection;
using System.IO;
using System.Threading.Tasks;
using MySql.Data.EntityFrameworkCore.Extensions;
using Microsoft.AspNetCore.Mvc.Infrastructure;
using Serilog;

namespace asm
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddLocalization(options => options.ResourcesPath = "Resources");

            // Add Options
            services.AddOptions();

            services.Configure<Options>(Configuration.GetSection("Properties"));

            services.AddDataProtection()
                .PersistKeysToFileSystem(new DirectoryInfo("/opt/app/key/"))
                .SetDefaultKeyLifetime(TimeSpan.FromDays(90));


            //Add MVC properties
            services.AddMvc()
                .AddViewLocalization()
                .AddDataAnnotationsLocalization();
            services.AddScoped<ILanguageActionFilter, LanguageActionFilter>();
            services.Configure<RequestLocalizationOptions>(
                options =>
                {
                    var supportedCultures = new List<CultureInfo>
                    {
                        new CultureInfo("es-AR"),
                        new CultureInfo("es"),
                        new CultureInfo("en-US"),
                        new CultureInfo("en")
                    };
                    options.DefaultRequestCulture = new RequestCulture(culture: "es-AR", uiCulture: "es-AR");
                    options.SupportedCultures = supportedCultures;
                    options.SupportedUICultures = supportedCultures;
                });


            // Add framework services.
            services.AddApplicationInsightsTelemetry(Configuration);

            services.AddDbContext<ApplicationDbContext>(options =>
                options.UseMySQL(Configuration.GetConnectionString("DefaultConnection"),
                b => b.MigrationsAssembly("asm"))
            );

            services.AddSingleton<Microsoft.AspNetCore.Identity.IdentityErrorDescriber, Services.Security.IdentityErrorDescriber>();

            services.AddIdentity<ApplicationUser, Role>((opt) =>
            {
                opt.Password.RequireDigit = true;
                opt.Password.RequireLowercase = true;
                opt.Password.RequireNonAlphanumeric = false;
                opt.Password.RequireUppercase = true;
                opt.Password.RequiredLength = 6;
            })
                .AddEntityFrameworkStores<ApplicationDbContext>()
                .AddDefaultTokenProviders();

            //Add Memory Cache
            services.AddMemoryCache();

            services.AddDistributedMemoryCache();

            services.AddSession(options => { options.CookieName = ".cookie.name"; options.IdleTimeout = TimeSpan.FromMinutes(40); });

            // Security
            services.AddAuthorization(options =>
            {
                options.AddPolicy("User Register", policy => policy.RequireClaim("UserRegister"));
                options.AddPolicy("Portal Policy", policy => policy.RequireClaim("PortalClaim"));
            });

            #region GlobalIsoDependencies

            // Redacted: Lots of services like: 
            // services.AddScoped<ThingRepository, ThingRepository>();

        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public async void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory, IServiceScopeFactory scopeFactory)
        {
            loggerFactory.AddConsole(Configuration.GetSection("Logging"));

            loggerFactory.AddDebug();

            loggerFactory.AddSerilog();

            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
                app.UseDatabaseErrorPage();
                app.UseBrowserLink();
            }
            else
            {
                app.UseExceptionHandler("/Home/Error");
            }

            app.UseStaticFiles();

            var options = app.ApplicationServices.GetService<Microsoft.Extensions.Options.IOptions<RequestLocalizationOptions>>();
            app.UseRequestLocalization(options.Value);

            app.UseAuthentication();

            app.UseSession();

            // Add external authentication middleware below. To configure them please see http://go.microsoft.com/fwlink/?LinkID=532715

            app.UseMvc(routes =>
            {
                routes.MapRoute(
                    name: "default",
                    template: "{controller=Home}/{action=Index}/{id?}");
            });

        }

    }
}

ApplicationDbContext.cs(也已编辑):

using System;
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore;
using crm.Models;
using crm.Models.GlobalIso;
using crm.Models.EmailMarketing;
using crm.Models.Idomum;
using crm.Models.Integrations.Mercadopago;
using crm.Models.GlobalIso.MA;
using crm.Models.GlobalIso.Type;
using crm.Models.GlobalIso.RT;
using crm.Models.GlobalIso.Maintenance;
using crm.Models.Crm;

namespace asm.Data
{
    public class ApplicationDbContext : IdentityDbContext<ApplicationUser, Role, string>
    {
        public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
            : base(options)
        {
        }

        protected override void OnModelCreating(ModelBuilder builder)
        {
            base.OnModelCreating(builder);

            // Redacted: Lots of:
            // builder.Entity<>(ClassName).ToTable("TABLE_NAME");

            builder.Entity<Profile>().ToTable("ROLE_PROFILE");
            builder.Entity<UserProfile>().ToTable("ROLE_PROFILE_USER");
            builder.Entity<ProfileRole>().ToTable("ROLE_PROFILE_ROLE");

            String longtext = "LONGTEXT";

            builder.Entity<ApplicationUser>()
                .HasMany(e => e.Claims)
                .WithOne()
                .HasForeignKey(e => e.UserId)
                .IsRequired()
                .OnDelete(DeleteBehavior.Cascade);

            builder.Entity<ApplicationUser>()
                .HasMany(e => e.Logins)
                .WithOne()
                .HasForeignKey(e => e.UserId)
                .IsRequired()
                .OnDelete(DeleteBehavior.Cascade);

            builder.Entity<ApplicationUser>()
                .HasMany(e => e.Roles)
                .WithOne()
                .HasForeignKey(e => e.UserId)
                .IsRequired()
                .OnDelete(DeleteBehavior.Cascade);


            builder.Entity<ApplicationUser>()
            .HasOne(p => p.Enterprise)
            .WithMany(e => e.ApplicationUserList);

            builder.Entity<Role>()
            .HasOne(p => p.Application);

            builder.Entity<UserProfile>()
                .HasKey(up => new { up.ApplicationUserID, up.ProfileID });

            builder.Entity<UserProfile>()
                .HasOne(up => up.ApplicationUser)
                .WithMany(u => u.UserProfileList)
                .HasForeignKey(up => up.ApplicationUserID);

            builder.Entity<UserProfile>()
                .HasOne(up => up.Profile)
                .WithMany(p => p.UserProfileList)
                .HasForeignKey(up => up.ProfileID);

            builder.Entity<ProfileRole>()
                .HasKey(pr => new { pr.RoleID, pr.ProfileID });

            //TODO: The key {'RoleID'} contains properties in shadow state and is referenced by a relationship from 'Role.PerfileRoleList' to 'PerfileRole.Role'.
            //Configure a non-shadow principal key for this relationship.
            builder.Entity<ProfileRole>()
                .HasOne(pr => pr.Role)
                .WithMany(r => r.ProfileRoleList)
                .HasForeignKey(pr => pr.RoleID);


            builder.Entity<ProfileRole>()
                .HasOne(pr => pr.Profile)
                .WithMany(p => p.ProfileRoleList)
                .HasForeignKey(pr => pr.ProfileID);


            builder.Entity<Enterprise>()
                .HasOne(tc => tc.Enterprise_Parent)
                .WithMany(p => p.EnterpriseChildList)
                .HasForeignKey(tc => tc.Enterprise_ParentID);

            builder.Entity<UserEnterprise>()
                .HasKey(t => new { t.ApplicationUserID, t.EnterpriseID });

            builder.Entity<UserEnterprise>()
                .HasOne(ue => ue.ApplicationUser)
                .WithMany(p => p.UserEnterpriseList)
                .HasForeignKey(tc => tc.ApplicationUserID);

            builder.Entity<UserEnterprise>()
                .HasOne(ue => ue.Enterprise)
                .WithMany(p => p.UserEnterpriseList)
                .HasForeignKey(tc => tc.EnterpriseID);
        }

        public DbSet<Enterprise> Enterprise { get; set; }
        public DbSet<UserEnterprise> UserEnterprise { get; set; }
        public DbSet<ApplicationUser> ApplicationUser { get; set; }

        public DbSet<Application> Application { get; set; }

        public DbSet<ApplicationEnterprise> ApplicationEnterprise { get; set; }


        // Many to Many Relations
        public DbSet<UserSettings> UserSettings { get; set; }

        public DbSet<Profile> Profile { get; set; }
        public DbSet<ProfileRole> ProfileRole { get; set; }
        public DbSet<UserProfile> UserProfile { get; set; }


    }
}

Program.cs

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using asm.Models;
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;

namespace asm
{
    public class Program
    {
        public static void Main(string[] args)
        {
            var host = BuildWebHost(args);

            using (var scope = host.Services.CreateScope())
            {
                var services = scope.ServiceProvider;

                try
                {
                    SeedData.Initialize(services).Wait();
                }
                catch (Exception ex)
                {
                    var logger = services.GetRequiredService<ILogger<Program>>();
                    logger.LogError(ex, "An error occurred seeding the DB.");
                }

            }
            host.Run();
        }

        public static IWebHost BuildWebHost(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
            .UseStartup<Startup>()
            .Build();

    }
}

0 个答案:

没有答案