UserControl中的EF无法看到app.config?

Sve*_*ven 6 c# user-controls entity-framework windows-forms-designer

我刚刚创建了一个用户控件.此控件还使用我的静态实体框架类来加载两个组合框.一切都很好,运行没有问题.设计和运行时正在运行.然后,当我停止应用程序时,包含我的UserControl的所有表单在设计时不再有效.我只看到两个错误:

错误1:在配置中找不到指定的命名连接,不打算与EntityClient提供程序一起使用,或者无效.

错误2:变量ccArtikelVelden未声明或从未分配.(ccArtikelVelde是我的UserControl)

运行时一切都还在运行

我的静态EF Repositoy类:

public class BSManagerData
{
    private static BSManagerEntities _entities;
    public static BSManagerEntities Entities
    {
        get
        {
            if (_entities == null)
                _entities = new BSManagerEntities();
            return _entities;
        }
        set
        {
            _entities = value;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

我的UserControl中发生了一些逻辑,用于加载组合框中的数据:

private void LaadCbx()
{
    cbxCategorie.DataSource = (from c in BSManagerData.Entities.Categories
                               select c).ToList();
    cbxCategorie.DisplayMember = "Naam";
    cbxCategorie.ValueMember = "Id";
}

private void cbxCategorie_SelectedIndexChanged(object sender, EventArgs e)
{
    cbxFabrikant.DataSource = from f in BSManagerData.Entities.Fabrikants
                              where f.Categorie.Id == ((Categorie)cbxCategorie.SelectedItem).Id
                              select f;
    cbxFabrikant.DisplayMember = "Naam";
    cbxFabrikant.ValueMember = "Id";
}
Run Code Online (Sandbox Code Playgroud)

使表单再次工作的唯一方法是设计时间,即在UserControl中注释掉EF部分(见上文)并重建.这很奇怪,一切都在同一个程序集中,相同的命名空间(为了简单起见).

有人有想法吗?

San*_*ken 9

看起来你在设计模式下以某种方式执行数据库代码.为了防止这种情况,请搜索导致此问题的控件和方法,并使用:

if (DesignMode)
    return
Run Code Online (Sandbox Code Playgroud)

此外,静态缓存数据库上下文是一个非常糟糕的主意.它会导致多线程问题,以及进行插入和删除时的问题.数据库上下文用于单个"工作单元",添加2,删除3个其他对象并调用SaveChanges一次.