0

完整的代码可以在这里找到:http: //home.htw-berlin.de/~s0531210/eb/DataBaseTest.zip

这是一个带有测试实体框架的简单项目。我有一个允许访问 SQL Server Compact 数据库的 DLL。此访问由 Enttiy Framework 5.0 进行。

第二个项目是访问此 DLL 的控制台应用程序。从 DLL 调用类以将示例数据存储到数据库中时,异常是“错误基础提供程序打开”。

调用时出现此异常:db.SaveChanges();

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;



namespace DatabaseLibrary
{
    public class SLD
    {
        public SLD()
        {
        }

        public void enterData()
        {
            using (var db = new SLDDatabaseModelEntitiesContext())
            {
                for (int i = 0; i < 10; i++)
                {
                    SLDEntity entrysfoo = new SLDEntity();
                    entrysfoo.Flip = i;
                    entrysfoo.Slidename = "bla" + i;
                    db.SLDEntity.Add(entrysfoo);
                }
                db.SaveChanges(); //DAtanbank speichern
            }
        }

        public SLDEntity getFromDataBase(string wsiname)
        {
            using (var db = new SLDDatabaseModelEntitiesContext())
            {
                foreach (var item in db.SLDEntity)
                {
                    if (item.Slidename.Equals(wsiname))
                    {
                        return item;
                    }
                }
            }

            return new SLDEntity();
        }
    }
}

我希望你们能帮助我。我不知道问题出在哪里。我在互联网上搜索了一些关于权限 iusses 的信息,但连接字符串是 reqiredpermissin=false。

4

1 回答 1

0

感谢连接字符串的提示。数据库不在控制台应用程序中的 App.config 文件指向的位置。但我不明白为什么dll中的连接字符串,其中一个也有一个App.config文件被忽略。如果我想要,连接字符串仅在 DLL 中可用,我是否必须通过命令手动设置 DLL 中的连接字符串?

于 2013-07-11T13:29:37.247 回答