繁体   English   中英

实体框架MySQL DbContext无法连接

[英]Entity Framework MySQL DbContext cannot connect

我使用代码优先而不是在App.config中存储密码的情况下创建了一个模型,而是将其传递给DbContext的构造函数:

public TasksWithoutPasswordContext(string nameOrConnectionString) : base(nameOrConnectionString)
{
    this.Database.Connection.ConnectionString = nameOrConnectionString;
}

但是尝试获取DbContext的DbSet时遇到运行时错误:

using (TasksWithoutPasswordContext contextWithoutPassword = new TasksWithoutPasswordContext(connectionString))
{
    foreach (var user in contextWithoutPassword.users)
    {
        MessageBox.Show(user.user);
    }
}

附加信息:建立与SQL Server的连接时发生与网络相关或特定于实例的错误。 服务器未找到或无法访问。 验证实例名称正确,并且已将SQL Server配置为允许远程连接。 (提供程序:命名管道提供程序,错误:40-无法打开与SQL Server的连接)。

我试图将我的课程标记为下一个:

[DbConfigurationType(typeof(MySql.Data.Entity.MySqlEFConfiguration))]
public class TasksWithoutPasswordContext : DbContext

并没有帮助。

当您自己找到解决方案时,我添加了答案:

从DbContext继承并调用基本构造函数时,可以使用default-base-constructor(无参数的构造函数)并在构造函数中设置连接字符串:

public TasksWithoutPasswordContext(string nameOrConnectionString) : base() 
{
    this.Database.Connection.ConnectionString = nameOrConnectionString;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM