我的.mdf db上有这个模型:
这两个表没有数据:
personid是外键。
这是我的EF模型图:
这是添加人员的代码。

    namespace DBTest
{
    class Class1
    {
        MyDBEntities db;
        public Class1()
        {
            db = new MyDBEntities();
            AddPerson();
        }


        void AddPerson()
        {
            Person p = new Person();
            p.ID=1;
            p.NAME="abcd";
            db.AddToPerson(p);
            db.SaveChanges();
        }
    }
}

在我从主教室打电话给全班同学之后:
    namespace DBTest
{
    class Program
    {
        static void Main(string[] args)
        {
            Class1 a = new Class1();
        }
    }
}

我想看看我的.mdf数据库有没有变化。
我发现数据库仍然为空(刷新后):
有人知道我需要做什么来更新数据库吗?
我做错什么了?
编辑:
连接字符串:
    <connectionStrings>
    <add name="DBTest.Properties.Settings.XXXXConnectionString" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\XXXX.mdf;Integrated Security=True;User Instance=True" providerName="System.Data.SqlClient" />
    <add name="MyDBEntities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\MyDB.mdf;Integrated Security=True;User Instance=True;MultipleActiveResultSets=True&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>

最佳答案

你没有给我们显示你的连接字符串-但我只是从你报告的“症状”中猜出来。
整个用户实例和attachdbfilename=方法都有缺陷-最多!在visual studio中运行应用程序时,它将在.mdf文件周围复制(从App_Data目录复制到输出目录-通常是在.\bin\debug中运行应用程序),而且很可能,您的INSERT工作得很好-但您最终看到的是错误的.mdf文件!
如果您想坚持使用这种方法,那么尝试在myConnection.Close()调用上设置一个断点,然后使用sql server mgmt studio express检查.mdf文件-我几乎可以肯定您的数据在那里。
我认为真正的解决办法是
安装SQL Server Express(您已经安装了)
安装SQL Server Management Studio Express
在SSMS Express中创建数据库,给它一个逻辑名称(例如MyDB
使用它的逻辑数据库名称(在服务器上创建时提供)连接到它,不要乱动物理数据库文件和用户实例。在这种情况下,连接字符串如下:

Data Source=.\\SQLEXPRESS;Database=MyDB;Integrated Security=True

其他一切都和以前一样…

关于c# - EF savechanges()对我的.mdf数据库无效,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16003583/

10-11 03:53
查看更多