繁体   English   中英

实体框架无法通过DLL访问数据库

[英]Entity Framework doesnt access via DLL to a Database

完整的代码可以在这里找到: 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();
        }
    }
}

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

感谢提示与连接字符串的工作。 该数据库不在console.app指向的App.config文件所在的位置。 但是我不明白为什么dll中的连接字符串(其中也有一个App.config文件)会被忽略。 如果需要连接字符串仅在DLL中可用,是否必须通过命令在DLL中手动设置连接字符串?

暂无
暂无

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

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